docker MySQL 密码报错,重新修改保留原样的数据

当前状态是:

  • MySQL 能正常启动
  • root 已经被设置过认证信息
  • 你现在不知道它的有效密码,或者认证插件不匹配

你刚才的结果已经把"现在是空密码"排除了。你贴的启动日志也说明这个库后来一直在正常使用,不是刚初始化的新空库。

现在最稳的处理方式是:直接重置 root 密码


保留现有数据,重置 root 密码

先停掉当前容器:

bash 复制代码
docker stop deeptest-mysql

然后用同一份数据目录,临时以"跳过权限表"的方式启动一个恢复容器:

bash 复制代码
docker run --rm -d \
  --name mysql-reset \
  -p 3308:3306 \
  -v /root/test_software/data/mysql:/var/lib/mysql \
  mysql:8.0 \
  --skip-grant-tables --skip-networking=0

进入这个临时容器:

bash 复制代码
docker exec -it mysql-reset mysql -uroot

进去后先执行:

sql 复制代码
FLUSH PRIVILEGES;

再看看用户表里 root 的 host 和插件:

sql 复制代码
SELECT user, host, plugin FROM mysql.user WHERE user='root';

然后把密码统一改掉。先执行这两句:

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'deeptest123456';
ALTER USER 'root'@'%' IDENTIFIED WITH caching_sha2_password BY 'deeptest123456';

如果第二句报 Operation ALTER USER failed,说明没有 'root'@'%',那就忽略,只保留 localhost 那句。

再执行:

sql 复制代码
FLUSH PRIVILEGES;

退出:

sql 复制代码
exit

关掉恢复容器:

bash 复制代码
docker stop mysql-reset

再正常启动原容器:

bash 复制代码
docker start deeptest-mysql

最后测试登录:

bash 复制代码
docker exec -it deeptest-mysql mysql -uroot -p

输入:

text 复制代码
deeptest123456
相关推荐
Suroy10 小时前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭10 小时前
运行你的第一个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