1、跳过授权表(通用)

MySQL5.7.31忘记密码的解决方案_mysql

㈠ 跳过授权表重启数据库

① 关闭数据库
[root@node1 ~]# mysqladmin shutdown -p
Enter password:
② 跳过授权表启动

友情提示:启动过程可能会一波三折,冷静分析看报错,必能解决!

# /mysql_3306/bin/mysqld --defaults-file=/mysql_3306/my.cnf --skip-grant-tables --skip-networking=on  --user=mysql &

㈡ 刷新授权表(重要)

# mysql -uroot -p
Enter password:

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

㈢ 修改密码

mysql> alter user 'root'@'localhost' identified by '123';
Query OK, 0 rows affected (0.00 sec)

补充:如果未能成功,则使用以下语句修改密码

mysql> UPDATE mysql.user SET authentication_string = PASSWORD('MyNewPass') WHERE User = 'root' AND Host = 'localhost';
mysql> FLUSH PRIVILEGES;

修改密码后,使用jobs + kill命令,停止正在运行的mysqld进程。然后使用service启动服务

# jobs
# kill %1

# service mysql_3306 start