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
相关推荐
亚空间仓鼠1 小时前
Docker容器化高可用架构部署方案(六)
docker·容器·架构
tongluowan0071 小时前
MySQL中列数量及长度
数据库·mysql
前端老曹2 小时前
Docker 从入门到放弃:完整指南
运维·docker·容器
咖啡里的茶i3 小时前
在Docker环境中安装Hadoop cluster 实验报告一
hadoop·docker·容器
汪汪大队u3 小时前
续:从 Docker Compose 到 Kubernetes(2)—— 服务优化与排错
网络·后端·物联网·struts·容器
rabbit_pro3 小时前
Docker compose部署Ollama使用模型
linux·运维·docker
前进的李工3 小时前
MySQL慢查询日志优化实战
数据库·mysql·性能优化
ILL11IIL4 小时前
k8s的pod管理及优化
云原生·容器·kubernetes
咖啡里的茶i5 小时前
在Docker环境中安装Hadoop cluster 实验报告三
docker
笑洋仟5 小时前
docker的overlay2目录占用磁盘空间很大,清理办法
运维·docker·容器