docker下mysql镜像初始化

20 篇文章 0 订阅
14 篇文章 0 订阅

目录

1、介绍

2、部署及验证

2.1  场景复现

2.2  创建dockerfile

2.3  初始化脚本

2.4  构建镜像并查看

2.5  创建容器并验证

2.6  完成 


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;

2.6  完成 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_44250083

微信号:c_x_y_000

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值