在 Docker 容器内运行 MySQL 并执行 SQL 脚本文件

在 Docker 容器内运行 MySQL 并执行 SQL 脚本文件(如 cube_admin.sql),可以通过几种方式实现。以下是一种常见的方法,假设已经将 SQL 脚本文件 cube_admin.sql 放置在容器可以访问的位置(例如,通过 Docker 构建上下文复制进去,或者将其放置在容器可以挂载的卷中):

确保 SQL 脚本文件在容器中可用:

如果在构建 Docker 镜像时已经将 cube_admin.sql 文件包含在内,确保它位于容器内的某个目录,比如 /docker-entrypoint-initdb.d/(这个目录是 MySQL 官方镜像在容器启动时自动执行 SQL 脚本的默认位置)。但是,请注意,这种方法仅适用于容器首次启动时。

如果希望在容器已经运行后执行脚本,可能需要将文件复制到容器中,或者通过 Docker 卷将其挂载到容器内。

使用 docker exec 命令在运行的容器中执行命令:

如果已经将 cube_admin.sql 文件挂载到容器内的某个位置(比如 /sql/ 目录),可以使用 docker exec 命令在 MySQL 容器中运行 mysql 客户端,并通过 -e 选项传递执行脚本的命令。但是,由于 mysql 客户端不直接支持 -e 选项执行文件(它只支持执行单行 SQL 语句),需要使用 < 重定向符从文件中读取 SQL 命令。不过,由于 docker exec 不直接支持重定向,需要在容器内部执行一个 shell 命令来完成这一操作。

正确的命令可能看起来像这样:

bash 复制代码
docker exec -it mysql bash -c "mysql -u root -p < /sql/cube_admin.sql"

注意:这里的 -p 选项会提示您输入密码。如果不想在命令行中手动输入密码,有几种选择:

在构建 Docker 镜像时设置 MySQL 的 root 密码为空(不推荐,出于安全考虑)。

使用 MySQL 客户端的 --password 选项直接传递密码(但这样会在命令历史中留下密码痕迹)。

使用 Docker secrets 或其他更安全的方法来管理密码。

预先配置 MySQL 用户,并为其设置无需密码的登录(同样不推荐,除非在受信任的环境中)。

由于安全原因,通常建议避免在命令行中直接传递密码。相反,可以考虑使用 Docker secrets、环境变量(尽管它们也可能在进程列表中暴露)或交互式输入密码。

使用 Docker 卷:

另一种方法是将包含 cube_admin.sql 文件的目录挂载为 Docker 卷,然后在容器内部使用 mysql 客户端执行该文件。这可以通过在 docker run 命令中使用 --volume(或 -v)选项来实现。

请记住,执行这些操作时,需要有足够的权限来访问和运行 Docker 命令,以及访问 MySQL 容器和其中的数据。此外,始终确保SQL 脚本和数据库操作符合安全和数据完整性要求。

相关推荐
幽兰的天空15 分钟前
MySQL 面试题大全及答案解析
数据库·mysql
zmd-zk44 分钟前
spark读取hive和mysql的数据
大数据·hive·python·学习·mysql·spark
奥顺1 小时前
从零开始:PHP基础教程系列-第8篇:会话与Cookie管理
大数据·mysql·开源·php
暮雨疏桐2 小时前
同一个宿主机下, web docker 容器里的程序 访问 mysql 容器里的mysql
mysql·docker·容器
今天不coding2 小时前
MySQL的历史和地位
数据库·mysql
MineGi2 小时前
02. Docker:安装和操作
linux·docker
东阳马生架构3 小时前
Redis应用—5.Redis相关解决方案
mysql
小张快跑。3 小时前
服务器限制某个端口只允许特定IP访问(处理第三方依赖漏洞)
运维·服务器·网络协议·安全·docker
记录测试点滴4 小时前
【SQL】语句练习
数据库·sql
自信人间三百年5 小时前
从零开始学docker(五)-可用的docker镜像
运维·docker·容器