详解关于docker中利用Dockerfile构建mysql让mysql启动时自动执行sql文件

本文讲述构建mysql镜像在其基础上再实现启动过程中自动导入数据及数据库用户的权限设置,并且在新创建出来的容器里自动启动MySQL服务接受外部连接,主要是通过Dockerfile和shell脚本实现这一过程。

详细步骤

1、首先创建一个Dockerfile文件:
执行命令 # vi Dockerfile 进入编辑

	FROM mysql:5.7.20
 
	#设置免密登录
	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
执行命令 # vi serup.sh

#!/bin/bash
set -e
 
#查看mysql服务的状态,方便调试,这条语句可以删除
echo `service mysql status`
 
echo '1.启动mysql....'
#启动mysql
service mysql start
sleep 3
echo `service mysql status`
 
echo '2.开始导入数据....'
#导入数据
mysql < /mysql/schema.sql
echo '3.导入数据完毕....'
 
sleep 3
echo `service mysql 
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值