【Docker构建MySQL8.0镜像】

Docker构建MySQL8.0镜像

  • 部署流程
    • [1. 拉取docker镜像](#1. 拉取docker镜像)
    • [2. 创建数据卷,存放MySQL数据](#2. 创建数据卷,存放MySQL数据)
    • [3. 启动MySQL镜像](#3. 启动MySQL镜像)
    • [4. 初始化sql放入MySQL镜像](#4. 初始化sql放入MySQL镜像)
    • [5. 执行MySQL脚本](#5. 执行MySQL脚本)
    • [6. MySQL镜像打包](#6. MySQL镜像打包)
    • [7. MySQL镜像迁移](#7. MySQL镜像迁移)

部署流程

1. 拉取docker镜像

go 复制代码
docker pull mysql:8.0.35

拉取成功后就可以看到镜像了:

这里我们选择MySQL 8.0.35版本,因为在8.0.33及其之前的版本被扫出多个漏洞,所以决定使用比较新版本的8.0.35

2. 创建数据卷,存放MySQL数据

go 复制代码
docker volume create mysql_data8_35

最好在启动时自己准备好配置文件

3. 启动MySQL镜像

3.1 启动脚本

go 复制代码
docker run -d -e MYSQL_ROOT_PASSWORD=密码 --name mysql8 -d -p 13307:3306 -v mysql_data8_35:/var/lib/mysql -v /日志目录/log:/var/log/ -v /配置文件目录/my.cnf:/etc/mysql/my.cnf mysql:8.0.35

注意:上述启动命令需要修改密码日志目录配置文件目录等内容后才能执行

常见的mysql8配置文件 my.cnf

mysqld

datadir = /var/lib/mysql

secure-file-priv= NULL

sql-mode = "ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

!includedir /etc/mysql/conf.d/

character-set-server = utf8mb4

collation-server = utf8mb4_general_ci

init_connect='SET NAMES utf8mb4'

lower_case_table_names = 1

mysql

default-character-set=utf8mb4

client

default-character-set=utf8mb4

3.2 查看是否启动成功

4. 初始化sql放入MySQL镜像

4.1 查看镜像id

docker ps

4.2 往镜像中放入脚本

docker cp init.sql 84dc03543c0f:/root/init.sql

4.3 进入镜像

docker exec -it mysql8 bash

5. 执行MySQL脚本

  1. 执行前登录mysql,开启日志:set global general_log=1;
  2. 查询日志存放目录:show variables like 'general%';
  3. 后续可以在目录实时查看脚本执行情况
  4. 创建数据库:CREATE DATABASE IF NOT EXISTS 数据库名 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
  5. 执行MySQL脚本:mysql -uroot -p 数据库名 < /root/init.sql
    回车后输入密码
  6. 脚本执行完登录mysql去关闭日志:set global general_log=0;
    不关闭日志会导致数据堆积,mysql镜像越来越大

6. MySQL镜像打包

将MySQL镜像打成压缩包,后续就能直接把压缩包复制到别的服务器,实现镜像迁移

6.1 查看数据卷所在位置

go 复制代码
docker volume inspect mysql_data8_35


6.2 数据压缩

  • 进入目录: cd /var/lib/docker/volumes/mysql_data8_35
  • 压缩数据:tar -czvf mysql8-35.tar.gz _data/

6.3 镜像压缩

go 复制代码
docker save -o mysql8-35.tar mysql:8.0.35

6.4 最终结果

7. MySQL镜像迁移

1. 加载镜像

docker load -i mysql8-35.tar

加载后即可看到镜像

2. 解压数据卷文件

tar -zxvf mysql8-35.tar.gz

3. 启动镜像

启动指令:
docker run -d -e MYSQL_ROOT_PASSWORD=密码 --name mysql8 -d -p 13307:3306 -v 数据卷解压目录/_data:/var/lib/mysql -v 日志目录/logs:/var/log/mysql8 -v 配置文件目录/my.cnf:/etc/mysql/my.cnf mysql:8.0.35

上述指令的配置文件目录日志目录都是非必须的,如果不需要将对应 -v指令去掉即可

相关推荐
观测云2 小时前
Kubernetes CRD 方式配置容器日志采集最佳实践
容器·kubernetes·日志分析
i***22073 小时前
springboot整合libreoffice(两种方式,使用本地和远程的libreoffice);docker中同时部署应用和libreoffice
spring boot·后端·docker
羑悻的小杀马特5 小时前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
EAIReport11 小时前
企业级报表自动化:基于Docker的部署实践
运维·docker·自动化
tianyuanwo12 小时前
多平台容器化RPM构建流水线全指南:Fedora、CentOS与Anolis OS
linux·运维·容器·centos·rpm
r***934812 小时前
CentOS7安装Mysql5.7(ARM64架构)
adb·架构
敲上瘾15 小时前
【探索实战】:Kurator分布式统一应用分发平台的全面解析与实践指南
分布式·容器·kubernetes·serverless
cui_win15 小时前
Docker Compose 部署一个完整的Prometheus监控告警系统
docker·容器·prometheus
ALex_zry19 小时前
Docker Compose运维技术实战分享:从安装到架构解析
运维·docker·架构
roman_日积跬步-终至千里1 天前
【Docker】Docker Stop 后到底发生了什么?——从信号机制到优雅停机
运维·docker·容器