在 Dockerfile 中设置数据库并导入转储
在 Docker 环境中,在配置 MySQL 和导入数据库转储时通常会遇到困难构建过程。要解决这些问题,请考虑以下方法:
官方 MySQL Docker 映像包含一项在启动时启用数据导入的功能。这消除了在 Dockerfile 中手动创建数据库和转储导入步骤的需要。要实现此目的,请创建一个类似于以下内容的 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/data 目录中。卷映射将使其在位于 /docker-entrypoint-initdb.d 的容器内可访问。
在幕后,MySQL Docker 映像中的 docker-entrypoint.sh 脚本包含一个自动执行 SQL 的代码块在 /docker-entrypoint-initdb.d 中找到的文件:
for f in /docker-entrypoint-initdb.d/*; do case "$f" in *.sh) echo "<pre class="brush:php;toolbar:false">FROM n3ziniuka5/ubuntu-oracle-jdk:14.04-JDK8 VOLUME /var/lib/mysql CMD ["true"]: running $f"; . "$f" ;; *.sql) echo ": running $f"; "${mysql[@]}" < "$f" && echo ;; *) echo ": ignoring $f" ;; esac echo done
这确保了 data-dump.sql 文件在容器中执行
为了在容器重新启动和删除期间保持数据持久性,建议创建一个单独的数据容器。此类容器的 Dockerfile 可以简单为:
CMD ["true"] 命令用于防止容器退出。数据容器不需要处于启动状态即可保证数据持久化。
以上是如何在 Docker 环境中高效地将数据库转储导入 MySQL?的详细内容。更多信息请关注PHP中文网其他相关文章!