本文提要
本文目的不仅仅是创建一个MySQL的镜像,而是在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动MySQL服务接受外部连接,主要是通过Dockerfile和shell脚本实现这一过程。
至于这么做的原因可以看一下这篇文章《将数据的初始化放到docker中的整个工作过程(问题记录)》,为了实现和docker-compose整合,试了很多种方法都没法实现需求,最终是通过这种方法才解决掉问题。
搭建步骤
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/bashset -e#查看mysql服务的状态,方便调试,这条语句可以删除echo `service mysql status`echo '1.启动mysql....'#启动mysqlservice mysql start
sleep 3echo `service mysql status`echo '2.开始导入数据....'#导入数据mysql
这里是先导入数据,然后才是设置用户和权限,是因为mysql容器一开始为免密登录,Dockerfile中有如下设置:ENV MYSQL_ALLOW_EMPT