MySQL 忘记密码的解决办法

前段时间迁移一台服务器 MySQL 数据库,由于这台服务器时间比较久没有使用了,把密码忘记了,但是需要把数据库里的一些数据导出来,所以就在网上找了一下,总结出这篇 MySQL 数据库忘记密码的解决方案!

本文使用的是 CentOS 6 和 MySQL 5.6 版本,可能不同版本的命令稍有不同,大家可以根据系统版本查询相关命令。

首先确认要操作的 MySQL 服务器处于安全的状态,也就是没有人能够连接 MySQL 数据库。 因为在重新设置 MySQL 的 Root 密码的期间,在启动 Mysql 时不启动授权表功能,可以直接免密码登录。可以采用将 MySQL 对外的端口封闭,并且停止 Apache 以及所有的用户进程的方法实现服务器的准安全状态。最安全的状态是到服务器的 Console 上面操作,并且拔掉网线。 

1、skip-grant-tables 模式启动

修改 /etc/my.cnf 文件,在 [mysqld] 区域添加配置,并保存 my.cnf 文件,重启 MySQL 服务,在控制台登录 MySQL,如果出现输入密码,直接回车,就可以进入数据库了。

命令如下:

1
2
3
4
5
6
7
8
9
10
11
# 修改 /etc/my.cnf 文件
vim /etc/my.cnf
 
# 在 [mysqld] 区域添加配置,并保存 my.cnf 文件
skip-grant-tables
 
# 重启 MySQL
service mysqld restart
 
# 登录 MySQL
mysql -u root -p

2、修改 root 密码

1
2
3
4
5
6
7
8
9
10
11
# 登录 MySQL 后进入 mysql 数据库
use mysql;
 
# 修改 root 密码
update user set password=password('password') where user='root';
 
# 使密码生效
flush privileges;
 
# 退出
exit;

3、重启服务器

1
2
3
4
5
6
7
8
# 修改 /etc/my.cnf 文件
vim /etc/my.cnf
 
# 在 [mysqld] 区域删除改配置,保存 my.cnf 文件
# skip-grant-tables
 
# 重启 MySQL
service mysqld restart

4、测试连接

1
2
3
4
# root 登录
mysql -u root -p
 
# 系统会提示输入 root 的密码

也可以使用第三方客户端进行登录。

posted @   Charles Zhang  阅读(24789)  评论(4编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示