Docker + MySQL 在 Windows 11 上的本地安装部署文档

Docker + MySQL 在 Windows 11 上的本地安装部署文档

前置准备

  1. 确保 Docker Desktop 已在 Windows 11 上安装并运行
    • 打开 PowerShell 或终端,执行以下命令验证:

      powershell 复制代码
      docker --version
      docker info
    • 如果没有安装,请从 Docker 官网 下载并安装

步骤 1: 拉取 MySQL 镜像

在终端中执行以下命令拉取官方 MySQL 镜像(以最新稳定版 MySQL 8.0 为例):

powershell 复制代码
docker pull mysql:8.0

步骤 2: 创建数据持久化目录(推荐)

为了防止数据在容器销毁后丢失,我们在本地创建一个目录用于存储 MySQL 数据:

powershell 复制代码
# 在 D 盘(或你喜欢的其他位置)创建目录
mkdir D:\docker-data\mysql\data
mkdir D:\docker-data\mysql\conf
mkdir D:\docker-data\mysql\logs

步骤 3: 启动 MySQL 容器

执行以下命令启动 MySQL 容器:

powershell 复制代码
docker run -d \
  --name mysql-local \
  -p 3306:3306 \
  -v D:\\docker-data\\mysql\\data:/var/lib/mysql \
  -v D:\\docker-data\\mysql\\conf:/etc/mysql/conf.d \
  -v D:\\docker-data\\mysql\\logs:/var/log/mysql \
  -e MYSQL_ROOT_PASSWORD=root123456 \
  -e MYSQL_DATABASE=local_db \
  -e TZ=Asia/Shanghai \
  --restart=always \
  mysql:8.0

参数说明:

  • -d: 后台运行容器
  • --name: 给容器命名
  • -p 3306:3306: 端口映射(主机:容器)
  • -v: 目录挂载(持久化数据、配置、日志)
  • -e MYSQL_ROOT_PASSWORD: 设置 root 用户密码(必填!)
  • -e MYSQL_DATABASE: 启动时自动创建一个数据库(可选)
  • -e TZ: 设置时区
  • --restart=always: 容器随 Docker 启动自动重启

步骤 4: 检查容器状态

powershell 复制代码
# 查看容器运行状态
docker ps -a

# 查看 MySQL 日志
docker logs mysql-local

步骤 5: 连接测试

你可以使用以下任意一种方式连接 MySQL:

方式 1: 在容器内连接

powershell 复制代码
docker exec -it mysql-local mysql -u root -proot123456

方式 2: 用本地工具连接

使用 Navicat、DBeaver、MySQL Workbench 等工具:

  • 主机: localhost127.0.0.1
  • 端口: 3306
  • 用户: root
  • 密码: root123456

常用管理命令

powershell 复制代码
# 启动容器
docker start mysql-local

# 停止容器
docker stop mysql-local

# 重启容器
docker restart mysql-local

# 进入容器
docker exec -it mysql-local bash

# 删除容器(注意:数据如果有挂载不会丢失)
docker rm -f mysql-local

安全提示

  • 生产环境请不要使用过于简单的密码
  • 如不需要外网访问,建议只允许本地连接
  • 定期备份 D:\docker-data\mysql\data 目录
相关推荐
鹤鸣的日常11 分钟前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
流星白龙1 小时前
【MySQL高阶】26.事务(1)
数据库·mysql
这个DBA有点耶2 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构
用户3074596982072 小时前
EXPLAIN 执行计划 完全精通指南
mysql
我是谁??4 小时前
ubuntu22.04 通过docker部署vLLM(Qwen3-0.6B)大模型+New API+OpenWebUI
docker·容器·vllm
AI行业学习4 小时前
CC-Switch v3.16.1 官方下载 | 安装配置详细教程【2026.6.10】
java·开发语言·vue.js·python·mysql·eclipse·html
运维瓦工4 小时前
DevOps 生态介绍(十):Docker Compose 核心 YAML 配置详解与常用命令大全
spring cloud·docker·容器
云烟成雨TD4 小时前
Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers
人工智能·spring·docker
用户3074596982074 小时前
乐观锁与悲观锁
mysql
Plastic garden4 小时前
K8s(10)NFS 的动态 PV 创建数据库给k8s的mysql和redis
docker·容器·kubernetes