目录
1、介绍
原理:当Mysql容器首次启动时,会在 /docker-entrypoint-initdb.d目录下扫描 .sh,.sql,.sql.gz类型的文件。如果这些类型的文件存在,将执行它们来初始化一个数据库。这些文件会按照字母的顺序执行。默认情况下它们会初始化在启动容器时声明的MYSQL_DATABASE变量中的数据库。MYSQL_DATABASE这个变量默认是不存在的,必须在启动容器时候声明或定义,否则就扫描/docker-entrypoint-initdb.d目录下进行初始化,如下所示:
docker run --name mysql01 -e MYSQL_DATABASE=test_db -d mysql:latest
【这里是初始化定义的test_db数据库,如果没有MYSQL_DATABASE就进行扫描/docker-entrypoint-initdb.d目录,看是否有.sh,.sql,.sql.gz类型的文件,若有就进行初始化,没有就不进行初始化】
2、部署及验证
2.1 场景复现
在标准的官方MySQL镜像基础上制作一个新镜像,新镜像启动过程中检查/root/init.sql文件是否存在,如果存在就执行此初始化SQL,完成数据库的初始化,随后删除此文件,正常启动MySQL。init.sql里可以是创建hellodb数据库,里面有app_user表,并包括app_user的3条初始化数据。给出dockerfile以及整个制作镜像以及启动验证的截图和说明。
系统 | CentOS Linux release 7.6.1810 |
mysql镜像 | MYSQL_VERSION=8.0.20 |
2.2 创建dockerfile
[root@bogon ~]# cat dockerfile
FROM mysql:latest
COPY --chown=mysql:mysql init.sql /root/
RUN cp /root/init.sql /docker-entrypoint-initdb.d
RUN rm -fr /root/init.sql
[root@bogon ~]#
【COPY意思是:先使用chown修改init.sql的用户属性,执行初始化数据库最好使用mysql用户来进行,当然root用户也是可以的,用户属性修改完毕再将init.sql复制到容器的/root/下面】
2.3 初始化脚本
[root@bogon ~]# cat init.sql
create database hellodb;
use hellodb;
create table app_user(name varchar(128) not null,age int not null,primary key(name));
insert into app_user values("jack","11"),("bob","4"),("tom","3");
[root@bogon ~]#
2.4 构建镜像并查看
docker build -t mysql:new .
docker images
2.5 创建容器并验证
docker run -d --name 001 -e MYSQL_ROOT_PASSWORD=123456 mysql:new
docker exec -it 001 bash
root@a929607c2da8:/# ls -l /root
total 0 【为空正常】
root@a929607c2da8:/# ls -l /docker-entrypoint-initdb.d/
total 4 【有init.sql文件正常,这是初始化文件,必须存在】
-rw-r--r--. 1 root root 190 Jun 20 13:48 init.sql
root@a929607c2da8:/#
mysql -uroot -p123456
show databases;
use hellodb;
show tables;
desc app_user;