【Docker部署】Docker-compose部署mysql容器及创建数据库失败问题

本文记录了使用Docker-compose部署MySQL时遇到的数据库创建失败问题。通过检查发现,当数据文件夹不为空时,数据库初始化无法成功。解决方案是确保在执行docker-compose up命令前清空映射的MySQL数据库文件夹,删除可能存在的隐藏文件。注意这个细节对于成功启动并创建数据库至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

     最近在尝试用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中不为空的情况:
在这里插入图片描述

     对比创建数据库成功的日志:
在这里插入图片描述

小结

     点滴的积累,时间会告诉你答案~

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奔跑的大白啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值