首页 >数据库 >mysql教程 >如何在 Docker 容器中使用预定义架构初始化 MySQL 数据库?

如何在 Docker 容器中使用预定义架构初始化 MySQL 数据库?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-09 06:39:07306浏览

How to Initialize a MySQL Database with a Predefined Schema in a Docker Container?

在 Docker 中使用 Schema 初始化 MySQL 数据库

问题

Docker 用户在初始化时遇到困难使用 Dockerfile 具有预定义架构的 MySQL 数据库。尽管遵循文档指南,旨在运行架构脚本的 CMD 命令还是失败,从而导致无法成功创建容器。

解决方案

该解决方案涉及顺序方法:

  1. 将 MySQL 架构转储到文件:
    导出数据库架构使用 mysqldump 命令复制到文件。
  2. 将 Schema 文件添加到 Docker 容器:
    在 Dockerfile 中,使用 ADD 命令将 schema.sql 文件复制到 /docker-入口点-initdb.d 目录。此目录允许在数据库初始化时自动执行脚本。
  3. 启动 Docker MySQL 实例:
    使用指定的 MySQL 映像和更新的 Dockerfile 启动 Docker 容器。

示例Dockerfile:

FROM mysql:5.7.15

MAINTAINER me

ENV MYSQL_DATABASE=<schema_name> \
    MYSQL_ROOT_PASSWORD=<password>

ADD schema.sql /docker-entrypoint-initdb.d

EXPOSE 3306

附加说明:

  • docker-entrypoint.sh 脚本将自动执行所有带有“.sql”的文件/docker-entrypoint-initdb.d 目录中的扩展。
  • 此方法允许初始化MySQL 数据库在容器创建时带有架构,无需手动干预。

以上是如何在 Docker 容器中使用预定义架构初始化 MySQL 数据库?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn