Skip to content

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

Docker-compose部署mysql: Docker-compose.yml 文件

yml
services:
  db:
    image: mysql:5.7
    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

文件目录结构: demo/ ├── db ├── config | └── my.cnf ├── docker-compose.yml └── init └── my_db.sql 说明:

文件名描述
conf/my.cnf配置文件
db数据文件
docker-compose.yml用来启动mysql 容器
init/prod.sql数据库初始化文件,此处放的是从数据库dump获得的sql

遇到问题:my_db 数据库未创建,这是为啥??

在各种重启容器、清空目录等操作下,终于成功了一次,原来是因为db文件必须是空文件夹,才可以执行创建数据库成功!!!

所以执行docker-compose up 命令之前,要清空映射mysql数据库文件的目录哦,有时候还会存在隐藏文件,也要删掉(rm -rf 执行时要注意执行的目录是否正确)!

查看此容器日志的命令如下:docker-compose logs my_db

对比创建数据库失败的日志(还有一些db中有文件时是没有提示信息的): [Note] [ERROR]: --initialize specified but the data directory has files in int. Aborting. [Note] [ERROR]: Aborting

对比创建数据库成功的日志: [Note] [Entrypoint]: Creating database my_db [Note] [Entrypoint]: /usr/local/bin/docker-entrypoint.sh: running /docker-entrypoint-initdb.d/my_db.sql

创作不易请尊重他人劳动成果,未经授权禁止转载!
Released under the MIT License.