mysql忘记初始临时密码解决方法

当遇到 "Access denied for user 'root'@'localhost' (using password: YES)" 这个错误时,除了密码本身不正确外,还有其他一些可能的原因和解决办法:

1. 忘记初始临时密码

正如之前提到的,首次安装启动 MySQL 时会生成一个临时密码。如果你没有使用这个临时密码去登录并修改密码,而是直接尝试设置新密码,就会出现这个错误。请务必使用初始生成的临时密码登录,然后再修改密码。

2. 密码存储格式与认证插件问题

不同的 MySQL 版本和配置可能使用不同的认证插件,这会影响密码的存储和验证方式。

  • 查看当前认证插件 : 登录到 MySQL 数据库(如果能登录的话),使用以下命令查看当前用户使用的认证插件:

    复制代码
    SELECT user, plugin FROM mysql.user WHERE user = 'root';

    如果插件不是 mysql_native_password,可能会导致密码验证问题。

  • 修改认证插件 : 如果你确定要使用 mysql_native_password 插件,可以使用以下命令修改 root 用户的认证插件:

    复制代码
    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_password';

    这里的 your_password 是你希望设置的密码。之后刷新权限:

    复制代码
    FLUSH PRIVILEGES;

3. 重置 root 用户密码

如果实在无法确定临时密码,或者上述方法都无效,可以尝试重置 root 用户密码。这通常需要以无密码验证的方式启动 MySQL 服务,不同操作系统和 MySQL 版本的操作略有不同,以下是一种常见的方法(适用于类 Unix 系统):

  1. 停止 MySQL 服务

    复制代码
    service mysql stop
  2. 以安全模式启动 MySQL : 在 my.cnfmy.ini 配置文件中添加或修改一行:

    复制代码
    [mysqld]
    skip-grant-tables

    保存配置文件后,重新启动 MySQL 服务:

    复制代码
    service mysql start
  3. 登录并修改密码 : 此时不需要密码即可登录 MySQL

    复制代码
    /usr/local/mysql/bin/mysql -uroot --socket=/var/lib/mysql/mysql.sock

    登录后,在 MySQL 命令行中执行以下操作来修改密码:

    复制代码
    USE mysql;
    UPDATE user SET authentication_string=PASSWORD('new_password') WHERE user='root' AND host='localhost';
    FLUSH PRIVILEGES;

    new_password 替换为你想要设置的新密码。

  4. 恢复正常启动 : 完成密码修改后,将配置文件中的 skip - grant - tables 这一行删除,然后重启 MySQL 服务,使其恢复正常的密码验证机制:

    复制代码
    service mysql stop
    # 删除或注释掉 skip - grant - tables 行
    service mysql start

4. 检查用户和主机匹配

确保 root 用户在 mysql.user 表中的 host 字段设置为允许连接的主机。例如,如果是本地连接,host 应该是 'localhost' 或者 '127.0.0.1'。可以通过以下命令查看:

复制代码
SELECT user, host FROM mysql.user WHERE user = 'root';

如果 host 字段的值不正确,可能会导致访问被拒绝。你可以使用以下命令修改:

复制代码
UPDATE mysql.user SET host = 'localhost' WHERE user = 'root' AND host!= 'localhost';
FLUSH PRIVILEGES;

通过以上步骤,应该能够解决 root 用户访问被拒绝的问题。

要在当前环境下执行这个查询,你需要先进入 MySQL 客户端。假设你的 MySQL 安装在 /usr/local/mysql 目录下,并且已经配置好了相关环境变量,你可以使用以下命令进入 MySQL 客户端:

bash复制代码

复制代码
/usr/local/mysql/bin/mysql -uroot -p --socket=/var/lib/mysql/mysql.sock

输入密码(如果有的话)后,你就进入了 MySQL 客户端环境,此时再执行 SELECT 语句:

sql复制代码

复制代码
SELECT user, host FROM mysql.user WHERE user = 'root';

这样就能得到关于 root 用户及其允许连接的主机信息。

如果你在执行进入 MySQL 客户端命令时遇到问题,比如提示找不到命令,那可能是因为没有正确配置环境变量。你可以将 /usr/local/mysql/bin 添加到系统的 PATH 环境变量中。在 bash 中,你可以使用以下命令临时添加:

bash复制代码

复制代码
export PATH=$PATH:/usr/local/mysql/bin

如果希望永久添加,可以将上述命令添加到 .bashrc.bash_profile 文件中,然后执行 source ~/.bashrcsource ~/.bash_profile 使更改生效。

相关推荐
呦呦鹿鸣Rzh40 分钟前
redis
数据库·redis·缓存
flying robot1 小时前
小结:Android系统架构
android·系统架构
xiaogai_gai1 小时前
有效的聚水潭数据集成到MySQL案例
android·数据库·mysql
web130933203982 小时前
Mysql的安装配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
数据库·mysql
三天不学习2 小时前
浅析AI大模型为何需要向量数据库?【入门基础】
数据库·人工智能·欧氏距离·向量数据库·余弦相似度
MonkeyKing_sunyuhua2 小时前
将数据库结构化数据整合到RAG问答中的方式
数据库
喝醉酒的小白2 小时前
MySQL内存使用率高问题排查与解决方案:
数据库
鹅鹅鹅呢2 小时前
mysql 登录报错:ERROR 1045(28000):Access denied for user ‘root‘@‘localhost‘ (using password Yes)
android·数据库·mysql
摘星编程2 小时前
Redis+Caffeine构建高性能二级缓存
数据库·redis·缓存
在人间负债^2 小时前
假装自己是个小白 ---- 重新认识MySQL
android·数据库·mysql