docker mysql启动时执行初始化sql

时间:2022-01-10 10:39:41

1.拉取Mysql镜像

docker pull mysql:5.7

2.检查mysql镜像

?
1
2
3
4
docker inspect mysql:5.7
"Entrypoint": [
 "docker-entrypoint.sh"
 ],

3.本地创建mysql外挂的目录

?
1
2
3
4
5
6
7
8
9
10
##挂载到容器内/docker-entrypoint-initdb.d;MySQL启动时将执行 01_create_database.sql
/root/mysql-5.7/init-data
  01_create_database.sql
  ##content
  create database test_database DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
  grant all privileges on `test_database`.* to 'test_user'@'%' identified by '123456';
  flush privileges;
 
##挂载到容器内 /var/lib/mysql
/root/mysql-5.7/mysql

4.启动mysql

?
1
docker run -p 33336:3306 -v /root/mysql-5.7/mysql:/var/lib/mysql -v /root/mysql-5.7/init-data:/docker-entrypoint-initdb.d -e MYSQL_ROOT_PASSWORD=123456 --name mysql_5.7 -d mysql/mysql:5.7

5.进入容器,登录mysql,检查发现已创建库 test_database

?
1
2
3
docker exec -ti <containerID> sh
mysql -uroot -p123456
show databases;

总结

以上所述是小编给大家介绍的docker mysql启动时执行初始化sql,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

原文链接:https://www.cnblogs.com/badboyh2o/archive/2019/05/23/10915267.html