mysql在docker容器中如何部署_利用docker-compose快速启动

MySQL容器必须挂载/var/lib/mysql到命名卷以持久化数据,root密码须通过MYSQL_ROOT_PASSWORD设置,配置应挂载到/etc/mysql/conf.d/,并显式声明端口与时区。docker-compose.yml 里 mysql 服务必须显式挂载 /var/lib/mysql不挂载会导致容器重启后数据全丢------因为 MySQL 默认把数据写在容器内文件系统,而 Docker 容器销毁即清空。哪怕只跑测试,也建议用命名卷,别依赖默认匿名卷。实操建议:用 docker volume create mysql-data 提前建好卷,再在 docker-compose.yml 中通过 volumes 映射到 /var/lib/mysql不要直接映射宿主机目录(比如 ./mysql-data:/var/lib/mysql),容易因文件权限问题导致 MySQL 启动失败:容器内 mysql 用户(UID 999)可能没权限读写宿主机目录如果非要用宿主机路径,得提前 chown -R 999:999 ./mysql-data,且该路径不能是 root 用户的家目录(某些 Linux 发行版会拒绝挂载)root 密码必须通过 MYSQL_ROOT_PASSWORD 环境变量传入MySQL 官方镜像完全忽略 my.cnf 里的 password 配置,也不接受 mysql_secure_installation 交互式设置。不设这个变量,容器会卡在初始化阶段并报错:ERROR 1045 (28000): Access denied for user 'root'@'localhost'。常见错误现象:容器反复重启,日志里出现 mysqld: Can't read dir of '/etc/mysql/conf.d/' ------ 实际是初始化失败的副产物,根源仍是密码没配用 MYSQL_PASSWORD 或 MYSQL_USER 单独配置但漏了 MYSQL_ROOT_PASSWORD,一样起不来密码含特殊字符(如 @、/、:)时,必须用单引号包裹整个值,否则 YAML 解析失败端口冲突和时区要手动指定 ports 与 environmentDocker 默认不暴露端口,不显式写 ports 就连不上;MySQL 容器默认用 UTC 时区,跟业务应用时区不一致会导致 NOW()、时间字段插入出错。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

相关推荐
用户8356290780519 小时前
使用 Python 操作 Word 内容控件
后端·python
源分享11 小时前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
码云骑士11 小时前
32-慢查询排查全流程(下)-索引优化实战与最左前缀原则
python
麦聪聊数据11 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_12 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
JAVA96512 小时前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
闵孚龙12 小时前
《PyTorch 深度修炼》Dataset 和 DataLoader:数据如何喂给模型
人工智能·pytorch·python
DARLING Zero two♡12 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
goldenrolan12 小时前
A公司物料替代测试系统 v1.7:从需求到 exe/apk 的 AI 辅助全链路实践
android·自动化测试·软件测试·python·ai