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
相关推荐
HackTwoHub14 分钟前
K8s综合渗透测试工具,集成信息搜集、权限逃逸、横向移动,一站式搞定全流程渗透测试工作
人工智能·安全·web安全·云原生·容器·kubernetes·系统安全
流星白龙29 分钟前
【MySQL高阶】20.InnoDB 磁盘文件
android·mysql·adb
AOwhisky42 分钟前
学习自测(MySQL系列第一期、第二期)
linux·运维·数据库·学习·mysql·云计算
人工智能培训1 小时前
数字孪生建模常用方式有哪些?
人工智能·深度学习·机器学习·容器·知识图谱
lpfasd1231 小时前
docker中默认网络的作用和注意事项
网络·docker·容器
IT策士1 小时前
第 37 篇 k8s之调度进阶:亲和性、污点与容忍
云原生·容器·kubernetes
念何架构之路1 小时前
存储层技术MySQL
数据库·mysql
EntyIU1 小时前
DOCKER_CHEATSHEET
运维·docker·容器
颜淡慕潇1 小时前
低成本搭建鸿蒙PC运行环境:基于 Docker 的 x86_64 服务器
服务器·docker·harmonyos
yun呐1 小时前
mysql数据库误删恢复
数据库·mysql·adb