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 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

相关推荐
weelinking1 天前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
一直不明飞行1 天前
Java的equals(),hashCode()应该在什么时候重写
java·开发语言·jvm
2301_803934611 天前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
WL_Aurora1 天前
Python爬虫实战(六):新发地蔬菜价格数据采集.
爬虫·python
盲敲代码的阿豪1 天前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
秋91 天前
windows中安装redis
数据库·redis·缓存
weixin199701080161 天前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python
Cosolar1 天前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap1 天前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel1 天前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步