Docker容器启动时初始化Mysql数据库

云栖号资讯:【点击查看更多行业资讯】
在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来!


1. 前言

Docker在开发中使用的越来越多了,最近搞了一个Spring Boot应用,为了方便部署将Mysql也放在Docker中运行。那么怎么初始化 SQL脚本以及数据呢?

我这里有两个传统方案。 第一种方案是在容0 g @ , b E器启动后手动导入,太low了不行。第二种在Spring Boot客户端连接Mysql容器l I p 6 z | ] A初始化数据库,你可以参考使用flyway进行数据库版本控制一文,但是这依赖客户端的能力。能不能做到Mysql容器启动时就自己初始化数据库呢?当然可以!今天就来演示一下。全部代码见文末。

2.原理

当Mysql容器首次启动时,会在 /docker-entrypoint-initdb.d目K H C r ~ K y R l录下扫描 .sh,.sql,.sql.gz类型的文件。如果这些类型的文件存在,将执行它们来初E S S {始化一个数据库。这些文件会按照字母的顺序执行。默认情况下它们会初始化在启动容器时声明的 MYSQT = w S T q $L_DATABASE变量定义的数据库中,例如下面的命令会初始化一个REGm I )ION_DB 数据库:

Docker容器启动时初始化Mysql数据库

如果你的启动命t M ? u x令没有指定数据库那么就必须在数据库DDL脚本中声明并指定使用该数据库。否则就会实现下面的异常:

那么接下来我们将利用这一机制来实现Docker容器启动时初始化数据库。

3.自定义Dockerfile

我们编写自己的Dockerfile来实现我们的需求,这里以 Mys & / - N - @sql:5.7 为例。不同的版/ u R b本可能有一定的出入,需要详细去阅读官方文档。脚本如下:

Docker容器启动时初始化Mysql数据库

  • 第一步,引入官方 Mysql:5.7 Docker镜像k Y p . w a ]
  • 第二步,无实际意义,主要是作者、组织信息。L } V H g w r
  • 第三步,很重要!本来我没有配置第三行,结果运行容器后发现初始化数据的中文全部乱码了。所以需要在初始化数据库前修改Mysql的编码等配置,这里我顺5 G g $ Y ( B R便把时区也改为了+8:00。
  • 第四步,复制包含数据库脚本的 ./sql文件夹到镜像的/tmp/sql下。
  • 第五步,使用 mv 命令把第四步拷贝的文件夹下的所有.sql文件复制到 /docker-entrypoint-initdb.d下,这样才能利用2.章节的机制进行初始化数据库。
  • 第六步,删除使用过的临时目录。

然后你可以通过构建镜像命令构建自定义的Mysql镜像:

Docker容器启动时初始化Mysql数据库

通过mysql:5.7c镜像启动一个名称为mysql-u Z ] mse` 3 P ` X & Rrvice的容器,rE I / o / h -oot密码为123456,并持久化数据到宿主机 D:/mysql/data下:

docker run --name mysql-service -v d:/mysql/data:/var/~ @ v v C `lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7c

小贴士:你可以通过 SHOW VARIl f . _ } + 6 SABLES LIKE 'character%' 查看字符集是否更改为utf8mb4,也可以通l F V y D , z Q过SHOW VARIABLESn Y L h LIKE '%time_zone%' 查看时区是否是东八区。

4. 总结

今天我们自定义一个可以执行| C ] [ . 6 x初始化数据库的Mysql镜像,方便我们进行部署。2 # o . 9 7 Y 你也可以参考这个思路来定制其它一些自己需要的Docker镜像。

【云栖号在线课堂】每天都有产品技术专家分享!
课程地址:http5 7 ~ ~ l E ]s://yqh.aliyun.com/live

立即加入社群,与专家面对面,及= Y s m时了解课程最新动态!
【云栖号在线课堂I l X c _ q o @ 社群】https://c.tb.cn/F3.Z8gvnK

原文发布时间:2020-05-27
W & A p j H D Z p文作者:码农小胖哥
本文来. P D r 7 Z Q _ Z自:“掘金”,了解相关: * b K & B : Z k信息可以关注“掘金”