首页 >数据库 >mysql教程 >如何在 Docker 容器中高效设置和导入 MySQL 转储?

如何在 Docker 容器中高效设置和导入 MySQL 转储?

Patricia Arquette
Patricia Arquette原创
2024-12-03 22:28:14536浏览

How to Efficiently Set Up and Import a MySQL Dump within a Docker Container?

Dockerfile 中的 MySQL 设置和转储导入

创建 Dockerfile 来设置 MySQL 数据库并导入转储是 Web 中的常见任务发展。但是,您可能会在 MySQL 启动过程中遇到问题。

提供的 Dockerfile 中的问题可能在于 MySQL 服务器缺少初始化阶段。要解决此问题,请考虑使用最新版本的官方 MySQL Docker 映像,该映像可简化容器启动期间的数据库创建和转储导入。

以下是演示此方法的 docker-compose.yml 示例:

data:
  build: docker/data/.
mysql:
  image: mysql
  ports:
    - "3307:3306"
  environment:
    MYSQL_ROOT_PASSWORD: 1234
  volumes:
    - ./docker/data:/docker-entrypoint-initdb.d
  volumes_from:
    - data

在此示例中,data-dump.sql 文件被挂载到容器上的 /docker-entrypoint-initdb.d 目录中。 Docker 入口点脚本在容器启动时处理导入过程。

此外,如果您希望在停止或删除 MySQL 容器后保留数据,请使用单独的数据容器。数据容器的 Dockerfile 的内容可以简化如下:

FROM n3ziniuka5/ubuntu-oracle-jdk:14.04-JDK8

VOLUME /var/lib/mysql

CMD ["true"]

通过此设置,无论 MySQL 容器的状态如何,数据都会被持久化。

以上是如何在 Docker 容器中高效设置和导入 MySQL 转储?的详细内容。更多信息请关注PHP中文网其他相关文章!

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