Docker使用run命令部署MySQL的流程步骤

 更新时间:2025年03月26日 08:42:13   作者:Kwan的解忧杂货铺  
容器化技术为数据库部署带来了革命性的变化,MySQL作为最流行的开源关系型数据库之一,结合Docker容器可以实现快速部署、环境隔离和便捷管理,本文给大家介绍了Docker使用run命令部署MySQL的流程步骤,需要的朋友可以参考下

一、MySQL 容器化概述

1.1 容器化部署优势

  • 环境一致性:消除"在我机器上能运行"的问题,确保开发、测试、生产环境完全一致
  • 快速部署:秒级启动 MySQL 实例,传统方式安装需要 10 分钟以上
  • 资源隔离:每个容器实例拥有独立的运行环境,避免资源冲突
  • 版本管理:轻松切换不同 MySQL 版本(5.7/8.0 等)
  • 便携性:镜像可跨平台运行,支持 x86/ARM 架构

1.2 官方镜像特点

MySQL 官方 Docker 镜像提供:

  • 多个版本选择(最新版/特定版本)
  • 基于 Alpine 和 Debian 的两种镜像
  • 自动初始化机制
  • 环境变量配置支持
  • 默认安全配置(非 root 运行)

二、基础部署实战

2.1 拉取官方镜像

获取最新 MySQL 8.0 镜像:

docker pull mysql:8.0

验证镜像:

docker image inspect mysql:8.0 | jq '.[0].Config.Env'

2.2 最小化启动命令

docker run -d \
  --name mysql-dev \
  -e MYSQL_ROOT_PASSWORD=my-secret-pw \
  -p 3306:3306 \
  mysql:8.0

参数说明:

  • -d:后台运行
  • --name:容器命名
  • -e:设置环境变量(必需设置 root 密码)
  • -p:端口映射(主机端口:容器端口)

2.3 连接验证

使用 MySQL 客户端连接:

mysql -h 127.0.0.1 -P 3306 -u root -p
# 输入密码my-secret-pw

容器内连接:

docker exec -it mysql-dev mysql -u root -p

三、数据持久化方案

3.1 挂载数据目录

创建数据目录:

mkdir -p ~/mysql-data/{data,conf.d,initdb}

启动容器:

docker run -d \
  --name mysql-prod \
  -v ~/mysql-data/data:/var/lib/mysql \
  -v ~/mysql-data/conf.d:/etc/mysql/conf.d \
  -v ~/mysql-data/initdb:/docker-entrypoint-initdb.d \
  -e MYSQL_ROOT_PASSWORD=strongpassword \
  mysql:8.0

目录作用:

  • /var/lib/mysql:MySQL 数据文件
  • /etc/mysql/conf.d:自定义配置文件
  • /docker-entrypoint-initdb.d:初始化 SQL 脚本

3.2 自定义配置文件

示例 my.cnf:

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
max_connections=200
innodb_buffer_pool_size=512M

3.3 数据库初始化

在 initdb 目录放置 SQL 文件:

echo "CREATE DATABASE appdb;" > ~/mysql-data/initdb/init.sql
echo "CREATE USER 'appuser'@'%' IDENTIFIED BY 'userpass';" >> ~/mysql-data/initdb/init.sql
echo "GRANT ALL ON appdb.* TO 'appuser'@'%';" >> ~/mysql-data/initdb/init.sql

四、安全加固配置

4.1 非 root 运行

docker run -d \
  --user mysql \
  --read-only \
  --cap-drop ALL \
  mysql:8.0

4.2 密码加密策略

docker run -d \
  -e MYSQL_ROOT_PASSWORD=securepass \
  -e MYSQL_SECURE_TRANSPORT=ON \
  -e MYSQL_SSL=ON \
  mysql:8.0

4.3 网络隔离

创建专用网络:

docker network create mysql-net

docker run -d \
  --network mysql-net \
  --name mysql-secure \
  -p 3306:3306 \
  mysql:8.0

五、高级管理技巧

5.1 性能调优参数

docker run -d \
  --name mysql-tuned \
  -e MYSQL_ROOT_PASSWORD=pass123 \
  -e MYSQL_INNODB_BUFFER_POOL_SIZE=1G \
  -e MYSQL_INNODB_LOG_FILE_SIZE=256M \
  -e MYSQL_MAX_CONNECTIONS=500 \
  mysql:8.0

5.2 主从复制配置

主库:

docker run -d \
  --name mysql-master \
  -e MYSQL_ROOT_PASSWORD=masterpass \
  -e MYSQL_REPLICATION_USER=repl \
  -e MYSQL_REPLICATION_PASSWORD=replpass \
  -e MYSQL_MASTER_PORT=3306 \
  mysql:8.0 \
  --server-id=1 \
  --log-bin=mysql-bin \
  --binlog-format=ROW

从库:

docker run -d \
  --name mysql-slave \
  --link mysql-master:master \
  -e MYSQL_ROOT_PASSWORD=slavepass \
  -e MYSQL_MASTER_HOST=master \
  -e MYSQL_MASTER_USER=repl \
  -e MYSQL_MASTER_PASSWORD=replpass \
  -e MYSQL_MASTER_PORT=3306 \
  mysql:8.0 \
  --server-id=2

5.3 备份恢复方案

执行备份:

docker exec mysql-prod sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > backup.sql

定时备份脚本:

#!/bin/bash
BACKUP_DIR=/path/to/backups
DATE=$(date +%Y%m%d_%H%M%S)
docker exec mysql-prod mysqldump -uroot -p${MYSQL_ROOT_PASSWORD} --all-databases | gzip > ${BACKUP_DIR}/backup_${DATE}.sql.gz
find ${BACKUP_DIR} -name "*.sql.gz" -mtime +7 -delete

六、生产环境部署建议

6.1 资源限制

docker run -d \
  --name mysql-production \
  --memory="4g" \
  --memory-swap="6g" \
  --cpus="2" \
  --blkio-weight=500 \
  mysql:8.0

6.2 监控配置

启用性能模式:

docker run -d \
  -e MYSQL_PERFORMANCE_SCHEMA=ON \
  mysql:8.0

集成 Prometheus:

docker run -d \
  -e MYSQL_EXPORTER=ON \
  -p 9104:9104 \
  mysql:8.0

6.3 高可用方案

使用健康检查:

docker run -d \
  --health-cmd="mysqladmin ping -uroot -p$$MYSQL_ROOT_PASSWORD" \
  --health-interval=10s \
  --health-timeout=3s \
  --health-retries=3 \
  mysql:8.0

七、常见问题排查

7.1 启动失败诊断

查看日志:

docker logs mysql-prod

常见错误:

  • 密码未设置:MYSQL_ROOT_PASSWORD环境变量缺失
  • 端口冲突:3306 端口已被占用
  • 权限问题:数据目录不可写

7.2 性能问题分析

查看运行状态:

docker exec -it mysql-prod mysqladmin -uroot -p status

慢查询日志:

docker exec mysql-prod sh -c 'cat /var/log/mysql/mysql-slow.log'

7.3 版本升级流程

  • 备份所有数据
  • 启动新版本容器:
docker run -d \
  --name mysql-new \
  -v ~/mysql-data/data:/var/lib/mysql \
  mysql:8.1
  • 运行 mysql_upgrade
  • 验证后切换流量

八、最佳实践总结

  1. 数据持久化:必须挂载/var/lib/mysql 目录
  2. 密码安全:使用强密码并定期更换
  3. 资源限制:根据服务器配置合理分配 CPU/内存
  4. 定期备份:实现自动化备份策略
  5. 监控告警:配置性能监控和异常告警
  6. 版本控制:明确记录使用的 MySQL 版本

到此这篇关于Docker使用run命令部署MySQL的流程步骤的文章就介绍到这了,更多相关Docker run部署MySQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • docker下载镜像太慢的解决方案

    docker下载镜像太慢的解决方案

    这篇文章主要介绍了docker下载镜像太慢的解决方案,具体操作步骤很详细也很简单,有遇到相同问题但是不知道如何解决的同学可以尝试下
    2021-03-03
  • 如何一次重启所有已停止的docker容器

    如何一次重启所有已停止的docker容器

    这篇文章主要介绍了如何一次重启所有已停止的docker容器问题,
    2024-01-01
  • Docker容器动态加载挂载目录的实践

    Docker容器动态加载挂载目录的实践

    本文主要介绍了Docker容器中动态加载挂载目录的实践,通过挂载目录,可以将主机上的文件或目录与容器中的文件或目录进行关联,实现应用程序的灵活性和可扩展性,这种方法可以避免容器重启,减少应用程序的停机时间,并简化应用程序的部署和管理,使应用程序的迁移和扩展更加容易
    2024-10-10
  • 如何查看docker容器运行进程信息

    如何查看docker容器运行进程信息

    这篇文章主要介绍了如何查看docker容器运行进程信息问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • MinIO在 Docker中修改登录账号和密码的步骤

    MinIO在 Docker中修改登录账号和密码的步骤

    本文介绍了如何在Docker容器中运行的MinIO修改登录账号和密码,包括备份数据、停止容器、删除旧容器、启动新容器并设置新的账号和密码以及验证修改结果的步骤,感兴趣的朋友一起
    2025-03-03
  • docker限制容器内存的方法详解

    docker限制容器内存的方法详解

    在服务器中使用 docker 时,如果不对 docker 的可调用内存进行限制,当 docker 内的程序出现不可预测的问题时,就很有可能因为内存爆炸导致服务器主机的瘫痪,本文将介绍使用 docker 进行容器内存限制的方法,感兴趣的朋友一起看看吧
    2023-11-11
  • docker如何删除<none>/dangling/悬空镜像

    docker如何删除<none>/dangling/悬空镜像

    这篇文章主要介绍了docker如何删除<none>/dangling/悬空镜像问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • docker 部署prometheus+grafana的过程详解

    docker 部署prometheus+grafana的过程详解

    这篇文章主要介绍了docker 部署prometheus+grafana的过程,本文通过示例图文相结合给大家介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • docker部署java项目的详细步骤

    docker部署java项目的详细步骤

    这篇文章主要介绍了docker部署java项目的详细步骤,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • Docker安装Nginx问题及错误分析

    Docker安装Nginx问题及错误分析

    这篇文章主要介绍了Docker安装Nginx的问题及错误分析正确的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12

最新评论