本文目的不仅仅是创建一个MySQL的镜像,而是在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动MySQL服务接受外部连接,主要是通过Dockerfile和shell脚本实现这一过程。
搭建步骤
1、首先创建Dckerfile:
FROM mysql:5.7
#设置免密登录
ENV MYSQL_ALLOW_EMPTY_PASSWORD yes
#将所需文件放到容器中
COPY setup.sh /mysql/setup.sh
COPY schema.sql /mysql/schema.sql
COPY privileges.sql /mysql/privileges.sql
#设置容器启动时执行的命令
CMD [“sh”, “/mysql/setup.sh”]
2、编写容器启动脚本setup.sh:
#!/bin/bash
set -e
**echo ‘1.启动mysql…’
#启动mysql
service mysql start
sleep 3
echo service mysql status
#重新设置mysql密码
echo ‘2.开始修改密码…’
mysql < /mysql/privileges.sql
echo ‘5.修改密码完毕…’
Dockerfile中有如下设置:ENV MYSQL_ALLOW_EMPTY_PASSWORD yes,此时执行导入数据命令不需要登录验证操作
3、mysql权限设置命令privileges.sql文件如下:
– 这一条命令一定要有:
FLUSH PRIVILEGES;
ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘12345’