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,如果出现输入密码,直接回车,就可以进入数据库了。

命令如下:

# 修改 /etc/my.cnf 文件
vim /etc/my.cnf

# 在 [mysqld] 区域添加配置,并保存 my.cnf 文件
skip-grant-tables

# 重启 MySQL 
service mysqld restart

# 登录 MySQL
mysql -u root -p

2、修改 root 密码

# 登录 MySQL 后进入 mysql 数据库
use mysql;

# 修改 root 密码
update user set password=password('password') where user='root';

# 使密码生效
flush privileges;

# 退出
exit;

3、重启服务器

# 修改 /etc/my.cnf 文件
vim /etc/my.cnf

# 在 [mysqld] 区域删除改配置,保存 my.cnf 文件
# skip-grant-tables

# 重启 MySQL
service mysqld restart

4、测试连接

# root 登录
mysql -u root -p

# 系统会提示输入 root 的密码

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

posted @ 2012-03-22 16:21  Charles Zhang  阅读(24786)  评论(4编辑  收藏  举报