本人环境为MySQL 5.7 + CentOS 6.3。
1. 编辑MySQL配置文件/etc/my.cnf
找到[mysqld],在下面添加一行skip-grant-tables
data:image/s3,"s3://crabby-images/7f835/7f835129e0470d1eff32c87905adf8d5973e1445" alt="CentOS 6.x下重置MySQL 5.7密码 CentOS 6.x下重置MySQL 5.7密码"
2. 重启MySQL
service mysqld restart
data:image/s3,"s3://crabby-images/ecb19/ecb190c2368c71a56aa932a082d48f78ea6381f2" alt="CentOS 6.x下重置MySQL 5.7密码 CentOS 6.x下重置MySQL 5.7密码"
3. root用户登录MySQL,提示密码直接回车
mysql -uroot -p
data:image/s3,"s3://crabby-images/43ad2/43ad2deb00844eae6b75721aee8b81a0b176598e" alt="CentOS 6.x下重置MySQL 5.7密码 CentOS 6.x下重置MySQL 5.7密码"
4. 修改root密码,并刷新权限
update mysql.user set authentication_string=password('新密码') where user='root' and host='localhost';
flush privileges;
data:image/s3,"s3://crabby-images/d7c9d/d7c9d6682db3fc3ed09aba09b7bd5b582db01c98" alt="CentOS 6.x下重置MySQL 5.7密码 CentOS 6.x下重置MySQL 5.7密码"
5. 退出MySQL,并编辑MySQL配置文件/etc/my.cnf
6. 重启MySQL
service mysqld restart7. 使用新密码登录,测试修改成果
注意:如果MySQL是5.5,则修改密码的语句是update mysql.user set password=password('123456') where user='root' and host='localhost';