【Docker部署】Docker-compose部署mysql容器及创建数据库失败问题
2022/1/8 2:03:32
本文主要是介绍【Docker部署】Docker-compose部署mysql容器及创建数据库失败问题,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 前言
- Docker-compose部署mysql
- Docker-compose.yml 文件
- 文件目录结构
- docker-compose 启动
- 启动后用navicat连接,发现创建了my_db数据库
- 遇到问题:my_db 数据库未创建,这是为啥??
- 小结
前言
最近在尝试用docker部署项目,在尝试初始化mysql 数据时遇到创建数据库失败的问题,卡了一段时间,特此记录下解决过程。
Docker-compose部署mysql
Docker-compose.yml 文件
services: db: image: mysql:5.7.36 container_name: my_db restart: always volumes: - ./db:/var/lib/mysql - ./conf/my.cnf:/etc/my.cnf # 数据库初始化脚本,当Mysql容器首次启动时,会在 /docker-entrypoint-initdb.d目录下扫描 .sh,.sql,.sql.gz类型的文件。如果这些类型的文件存在,将执行它们来初始化一个数据库; - ./init/:/docker-entrypoint-initdb.d/ environment: - MYSQL_ROOT_PASSWORD=admin123 # 指定初始化sql文件的数据库 - MYSQL_DATABASE=my_db - TZ=Asia/Shanghai ports: - 3301:3306
文件目录结构
说明:
文件名 | 描述 |
---|---|
conf/my.cnf | 配置文件 |
db | 数据文件 |
docker-compose.yml | 用来启动mysql 容器 |
init/prod.sql | 数据库初始化文件,此处放的是从数据库dump获得的sql |
docker-compose 启动
# 前台启动容器,控制台会打印容器启动的日志信息,方便看异常信息 docker-compose up
启动后用navicat连接,发现创建了my_db数据库
至此,一切顺利的话,mysql服务就成功启动啦!
遇到问题:my_db 数据库未创建,这是为啥??
这是未创建成功的画面:
各种怀疑sql脚本,本地数据库执行了一遍没啥问题啊,又怀疑docker-compose中挂载脚本目录问题,又确认了下没啥问题啊,然后在各种重启容器、清空目录等操作下,终于成功了一次,啧啧啧,,,原来是因为db文件必须是空文件夹,才可以执行创建数据库成功!!!
所以执行docker-compose up 命令之前,要清空映射mysql数据库文件的目录哦,有时候还会存在隐藏文件,也要删掉(rm -rf 执行时要注意执行的目录是否正确)!
对比创建数据库失败的日志(还有一些db中有文件时是没有提示信息的):
db中不为空的情况:
对比创建数据库成功的日志:
小结
点滴的积累,时间会告诉你答案~
这篇关于【Docker部署】Docker-compose部署mysql容器及创建数据库失败问题的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-25如何部署MySQL集群资料:新手入门教程
- 2024-12-24MySQL集群部署资料:新手入门教程
- 2024-12-24MySQL集群资料详解:新手入门教程
- 2024-12-24MySQL集群部署入门教程
- 2024-12-24部署MySQL集群学习:新手入门教程
- 2024-12-24部署MySQL集群入门:一步一步搭建指南
- 2024-12-07MySQL读写分离入门:轻松掌握数据库读写分离技术
- 2024-12-07MySQL读写分离入门教程
- 2024-12-07MySQL分库分表入门详解
- 2024-12-07MySQL分库分表入门指南