0

0

MySQL root账户密码如何重置?MySQL修复root密码的4种专业技巧

雪夜

雪夜

发布时间:2025-09-01 11:43:01

|

677人浏览过

|

来源于php中文网

原创

停止mysql服务;2. 以--skip-grant-tables模式启动mysql;3. 无密码登录并执行alter user或update语句修改root密码;4. 执行flush privileges使更改生效;5. 正常重启mysql服务,完成密码重置。该方法通过临时跳过权限验证实现密码重置,操作完成后系统恢复正常安全状态,整个过程符合官方规范且不会留下安全隐患,最终可使用新密码成功登录mysql。

MySQL root账户密码如何重置?MySQL修复root密码的4种专业技巧

MySQL root账户密码忘记或需要重置,这事儿说大不大,说小不小,但一旦遇上,确实挺让人头疼的。核心来说,它通常涉及到让MySQL服务在一个“不那么安全”但可控的状态下启动,这样我们就能绕过权限验证,进去把密码改掉。听起来有点像“破门而入”,但这是官方提供的一种紧急处理方式,只要操作得当,并不会带来额外的安全风险。

解决方案:MySQL root密码的4种专业重置技巧

1. 经典且稳妥:跳过权限验证表 (Skip Grant Tables) 方法

这是我个人觉得最常用,也最靠谱的一种方法。它的原理很简单,就是告诉MySQL服务器启动时“别检查权限了”,这样你就能以root身份无密码登录,然后修改密码。

步骤概述:

  1. 停止MySQL服务: 这是第一步,也是最关键的一步。你得让MySQL先歇着。

    sudo systemctl stop mysql  # 对于使用systemd的系统
    # 或者 sudo service mysql stop
    # 对于旧的init.d系统

    有时候,服务可能死活停不下来,那可能得用

    kill
    命令,找到
    mysqld
    进程的PID然后
    kill -9
    ,但这通常是万不得已。

  2. 以跳过权限表模式启动MySQL: 这一步是核心。我们用

    mysqld_safe
    mysqld
    命令,加上
    --skip-grant-tables
    参数。

    sudo mysqld_safe --skip-grant-tables &  # 后台运行,更方便
    # 或者 sudo mysqld --skip-grant-tables &

    如果你看到一些警告,比如关于

    validate_password
    插件的,先别管它,我们只是临时启动。

  3. 无密码登录MySQL: 现在,你可以直接用root用户登录了,不需要密码。

    mysql -u root
  4. 修改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()
      函数在这里很重要。

      晓象AI资讯阅读神器
      晓象AI资讯阅读神器

      晓象-AI时代的资讯阅读神器

      下载

    重要提醒:

    FLUSH PRIVILEGES;
    这句非常重要,它会重新加载权限表,让新密码生效。

  5. 停止MySQL并正常启动: 密码修改完成后,退出MySQL命令行(

    exit;
    ),然后停止之前用
    mysqld_safe
    启动的进程,再正常启动MySQL服务。

    sudo killall mysqld  # 停止之前后台运行的mysqld进程
    sudo systemctl start mysql # 正常启动MySQL
    # 或者 sudo service mysql start

    现在,你就可以用新密码登录了。

2. 更自动化:使用
mysqld --init-file
启动选项重置

这种方法在我看来,在某些自动化脚本或需要执行一系列复杂操作时特别有用。你把所有需要执行的SQL命令写到一个文件里,然后让MySQL在启动时自动执行这个文件。

步骤概述:

  1. 停止MySQL服务: 和上面一样,先让MySQL停下来。

    sudo systemctl stop mysql
  2. 创建SQL命令文件: 创建一个文本文件,比如

    reset_password.sql
    ,内容就是你修改密码的SQL语句。

    -- reset_password.sql
    ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';
    FLUSH PRIVILEGES;

    这个文件可以放在任何你方便访问的地方,比如

    /tmp/reset_password.sql

  3. **以 `init-file

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

683

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

321

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

347

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1095

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

676

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

575

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

417

2024.04.29

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 801人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号