Docker 部署 Mysql (图文并茂超详细)

部署 MYSQL ( Docker )

[Step 1] : 拉取 MYSQL 镜像

bash 复制代码
docker pull mysql:8.0.33

[Step 2] : 创建 MYSQL 相关目录 ➡️ 启动 MYSQL 容器 ➡️ 拷贝文件 ➡️ 授权文件夹 ➡️ 删除容器

bash 复制代码
# 创建 MYSQL 相关目录
mkdir -p /data/mysql/{conf,log,data}

# 启动 MYSQL 容器
docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=ovoAdmin123 -d mysql:8.0.33

# 拷贝文件 
docker cp mysql:/var/log /data/mysql
docker cp mysql:/etc/my.cnf /data/mysql/conf

# 授权文件夹
chmod 777 /data/mysql/{log,data}
chmod 644 /data/mysql/conf/my.cnf

# 删除容器
docker rm -f mysql
  • 对应的目录下会创建有相应的文件夹

[Step 3] : 创建 MYSQL 容器

bash 复制代码
docker run -p 3306:3306 --name mysql \
-v /data/mysql/log:/var/log/mysql \
-v /data/mysql/data:/var/lib/mysql \
-v /data/mysql/conf/my.cnf:/etc/mysql/my.cnf \
-e TZ=Asia/Shanghai --restart=always \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:8.0.33
  • 相关参数解释 :
  1. docker run: 创建并运行一个容器, -d是让容器在后台运行
  2. -- name mysql: 给容器起一个名字, 名字必须唯一
  3. -v /data/mysql/log:/var/log/mysql : 挂载配置文件
  4. -p 3306:3306: 设置端口映射
  5. -e KEY = VALUE: 设置环境变量 -e就是environment的意思
  6. TZ=Asia/Shanghai : 设置数据库时区为东八区
  7. --restart=always : 自启动 ( 服务器重启后会自启动 )
  8. MYSQL_ROOT_PASSWORD : 数据库密码
  9. mysql:指定运行的镜像的名字, 后面可以跟版本号, 如果不跟默认最新版

[Step 4] : 查看 MYSQL 日志

bash 复制代码
docker logs -f mysql
  • 没有 Error 就是启动成功了

[Step 5] : 使用工具连接 MYSQL


  • 填写连接信息
  • 测试连接成功 !
相关推荐
RestCloud2 小时前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
得物技术5 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
xiaok6 小时前
mysql中怎么创建一个可控权限数据库账号密码给到开发者
mysql
ByteBlossom9 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
muyun28009 小时前
Docker 下部署 Elasticsearch 8 并集成 Kibana 和 IK 分词器
elasticsearch·docker·容器
玉衡子9 小时前
九、MySQL配置参数优化总结
java·mysql
-Xie-10 小时前
Mysql杂志(十六)——缓存池
数据库·mysql·缓存
玉衡子10 小时前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
计算机毕业设计木哥10 小时前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计
傻傻虎虎14 小时前
【Docker】常用帮忙、镜像、容器、其他命令合集(2)
运维·docker·容器