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 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西
相关推荐
虹科网络安全1 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)阿坤带你走近大数据1 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小yoyo_zzm1 小时前
Laravel8.x新特性全解析2301_800976932 小时前
正则表达式码界奇点2 小时前
基于Python的新浪微博数据爬虫系统设计与实现AI木马人2 小时前
1.人工智能实战:大模型推理接口响应慢?从模型加载到 FastAPI 部署的完整优化方案青少儿编程课堂3 小时前
2026青少儿信息素养大赛备赛指南!Python/Scratch/C++备考要点我科绝伦(Huanhuan Zhou)3 小时前
探索技术世界:我的GitHub数据库工具宝库用户8356290780513 小时前
使用 Python 设置 Excel 数据验证