在 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 脚本和数据库操作符合安全和数据完整性要求。

相关推荐
Suroy9 小时前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭9 小时前
运行你的第一个Docker容器
后端·docker·容器
李白客1 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
宋均浩1 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
程序员老赵2 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程
WangMingHua1112 天前
LM Studio Docker 部署——本地大模型一键启动
docker
Jim6003 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
曲幽3 天前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
GreatSQL3 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql