完美解决 mysql 报错ERROR 1524 (HY000) Plugin ‘mysql_native_password‘ is not loaded

文章目录

跟着我下面的步骤走,解决你的问题,如果解决不了 私信我来给你解决

错误描述

执行ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';报错ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded 原因如下

错误原因

这个错误主要由以下几个原因造成:

  1. 插件未安装:MySQL的auth_socket插件可能没有被安装。这个插件允许用户通过操作系统的socket来进行身份验证,而不是使用密码。
  2. 配置问题:MySQL配置文件(my.cnf或my.ini)中可能没有正确配置auth_socket插件。
  3. 权限问题:即使插件已安装,但MySQL服务器的运行用户可能没有足够的权限来加载该插件。

解决步骤

确认插件是否已安装
首先,你需要确认auth_socket插件是否已经安装在你的MySQL服务器上。可以通过登录到MySQL服务器并执行以下SQL查询来检查:

SHOW PLUGINS;

在结果中查找auth_socketunix_socket(插件名称可能根据MySQL版本而异)。
我是没有找到 所以就安装吧

安装或启用插件
如果auth_socket插件未显示在已安装的插件列表中,你需要安装或启用它。可以通过以下SQL命令来安装:
进入到你的mysql容器中执行

INSTALL PLUGIN auth_socket SONAME 'auth_socket.so';

在这里插入图片描述
更改用户的认证方法
如果你已确认插件已安装并且想使用它,确保你的MySQL用户配置为使用该插件进行认证。你可以使用以下SQL命令更改用户的认证方法:

ALTER USER 'root'@'%' IDENTIFIED WITH auth_socket;ALTER USER 'your_username'@'localhost' IDENTIFIED WITH auth_socket;

替换root为你的实际用户名
然后我们在重新执行ALTER USER 'root'@'%' IDENTIFIED WITH auth_socket BY '123456';
注意这个地方不是mysql_native_password 而是auth_socket 因为咱创建的就是auth_socket
OK 完事!
在这里插入图片描述

### 关于 MySQL 报错 ERROR 1524 (HY000) 当尝试通过 `ALTER USER` 修改用户的密码验证方式时,如果收到错误提示 **ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded**,这通常是因为当前版本的 MySQL 不再默认支持 `mysql_native_password` 验证插件。 #### 错误原因 此问题的根本原因是自 MySQL 8.0 开始,默认的身份验证插件已更改为 `caching_sha2_password`,而不再是传统的 `mysql_native_password`。因此,在某些配置下,可能无法找到或加载 `mysql_native_password` 插件[^2]。 --- #### 解决方案 以下是几种可行的方法来解决问题: 1. **切换到新的身份验证插件 (`caching_sha2_password`)** 如果可以接受使用新插件,则可以通过以下命令更改用户的身份验证机制: ```sql ALTER USER 'root'@'%' IDENTIFIED WITH caching_sha2_password BY 'your_new_password'; ``` 2. **重新启用 `mysql_native_password`** 若仍需继续使用旧版插件,可通过修改用户设置实现兼容性: ```sql ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your_new_password'; FLUSH PRIVILEGES; ``` 此外,还需确认服务器端是否启用了该插件。可以在启动 MySQL 的时候显式指定允许加载 `mysql_native_password` 插件。 3. **调整全局参数以强制回退至传统模式** 编辑 MySQL 配置文件(通常是 `/etc/mysql/my.cnf` 或其他路径),并添加以下内容: ```ini [mysqld] default_authentication_plugin=mysql_native_password ``` 完成编辑后重启服务使变更生效: ```bash sudo systemctl restart mysqld ``` 以上操作能够有效处理因插件缺失引发的相关异常情况[^4]。 --- ### 示例代码片段 假设需要将 root 用户恢复为基于 `mysql_native_password` 的认证形式,可参照如下 SQL 脚本执行: ```sql -- 更改用户认证方式为 mysql_native_password 并重设密码 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'SecurePassword123'; -- 刷新权限表以应用最新改动 FLUSH PRIVILEGES; ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值