停止mysql服务;2. 以--skip-grant-tables模式启动mysql;3. 无密码登录并执行alter user或update语句修改root密码;4. 执行flush privileges使更改生效;5. 正常重启mysql服务,完成密码重置。该方法通过临时跳过权限验证实现密码重置,操作完成后系统恢复正常安全状态,整个过程符合官方规范且不会留下安全隐患,最终可使用新密码成功登录mysql。
MySQL root账户密码忘记或需要重置,这事儿说大不大,说小不小,但一旦遇上,确实挺让人头疼的。核心来说,它通常涉及到让MySQL服务在一个“不那么安全”但可控的状态下启动,这样我们就能绕过权限验证,进去把密码改掉。听起来有点像“破门而入”,但这是官方提供的一种紧急处理方式,只要操作得当,并不会带来额外的安全风险。
解决方案:MySQL root密码的4种专业重置技巧 1. 经典且稳妥:跳过权限验证表 (Skip Grant Tables) 方法这是我个人觉得最常用,也最靠谱的一种方法。它的原理很简单,就是告诉MySQL服务器启动时“别检查权限了”,这样你就能以root身份无密码登录,然后修改密码。
步骤概述:
-
停止MySQL服务: 这是第一步,也是最关键的一步。你得让MySQL先歇着。
sudo systemctl stop mysql # 对于使用systemd的系统 # 或者 sudo service mysql stop # 对于旧的init.d系统
有时候,服务可能死活停不下来,那可能得用
kill
命令,找到mysqld
进程的PID然后kill -9
,但这通常是万不得已。 -
以跳过权限表模式启动MySQL: 这一步是核心。我们用
mysqld_safe
或mysqld
命令,加上--skip-grant-tables
参数。sudo mysqld_safe --skip-grant-tables & # 后台运行,更方便 # 或者 sudo mysqld --skip-grant-tables &
如果你看到一些警告,比如关于
validate_password
插件的,先别管它,我们只是临时启动。 -
无密码登录MySQL: 现在,你可以直接用root用户登录了,不需要密码。
mysql -u root
-
修改root密码: 进入MySQL命令行后,根据你的MySQL版本,选择合适的修改密码语句。
-
MySQL 5.7.6 及更高版本,以及 MySQL 8.0+: 推荐使用
ALTER USER
语句,因为它更符合SQL标准,也更清晰。ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; FLUSH PRIVILEGES;
请把
'你的新密码'
替换成一个足够强壮的密码。 -
MySQL 5.7.5 及更早版本: 可以使用
UPDATE
语句直接修改mysql.user
表。UPDATE mysql.user SET authentication_string = PASSWORD('你的新密码') WHERE User = 'root'; FLUSH PRIVILEGES;
注意,
authentication_string
字段在不同版本中可能有所不同,老版本可能是password
字段。PASSWORD()
函数在这里很重要。
重要提醒:
FLUSH PRIVILEGES;
这句非常重要,它会重新加载权限表,让新密码生效。 -
-
停止MySQL并正常启动: 密码修改完成后,退出MySQL命令行(
exit;
),然后停止之前用mysqld_safe
启动的进程,再正常启动MySQL服务。sudo killall mysqld # 停止之前后台运行的mysqld进程 sudo systemctl start mysql # 正常启动MySQL # 或者 sudo service mysql start
现在,你就可以用新密码登录了。
mysqld --init-file启动选项重置
这种方法在我看来,在某些自动化脚本或需要执行一系列复杂操作时特别有用。你把所有需要执行的SQL命令写到一个文件里,然后让MySQL在启动时自动执行这个文件。
步骤概述:
-
停止MySQL服务: 和上面一样,先让MySQL停下来。
sudo systemctl stop mysql
-
创建SQL命令文件: 创建一个文本文件,比如
reset_password.sql
,内容就是你修改密码的SQL语句。-- reset_password.sql ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码'; FLUSH PRIVILEGES;
这个文件可以放在任何你方便访问的地方,比如
/tmp/reset_password.sql
。 **以 `init-file
以上就是MySQL root账户密码如何重置?MySQL修复root密码的4种专业技巧的详细内容,更多请关注知识资源分享宝库其它相关文章!
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。