当前位置: 首页 > news >正文

Plugin ‘mysql_native_password‘ is not loaded`

Plugin 'mysql_native_password' is not loaded`

      • mysql_native_password介绍
      • 1. 使用默认的认证插件
      • 2. 修改 my.cnf 或 my.ini 配置文件
      • 3. 加载插件(如果确实没有加载)
      • 4. 重新安装或检查 MySQL 版本

遇到错误 ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded 表示 mysql_native_password 插件在 MySQL 服务中没有加载或不可用。这种情况通常出现在新版的 MySQL 中,尤其是从 MySQL 5.7 升级到 MySQL 8.0 时,因为 MySQL 8.0 默认使用了更安全的认证插件 caching_sha2_password

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '含有大小写字母、数字、特殊字符的密码';ERROR 1524 (HY000): Plugin 'mysql_native_password' is not loaded

mysql_native_password介绍

使用的是基于SHA-1的密码散列算法。
SHA-1算法已被认为不再足够安全,存在一定的安全隐患,容易受到撞库攻击和其他形式的攻击

解决这个问题,你可以尝试以下几种方法:

1. 使用默认的认证插件

如果没有特别的需要使用 mysql_native_password,建议使用 MySQL 8.0 默认的 caching_sha2_password 认证插件。对于新用户,可以这样创建:

ALTER USER 'root'@'localhost' IDENTIFIED WITH caching_sha2_password BY 'Li4444555635!'; 

2. 修改 my.cnf 或 my.ini 配置文件

如果你确实需要使用 mysql_native_password,尝试在 MySQL 的配置文件(Linux 上通常是 /etc/my.cnf/etc/mysql/my.cnf,Windows 上是 my.ini)中添加以下设置,然后重启 MySQL 服务:

default_authentication_plugin=mysql_native_password

添加这段配置后,新创建的用户将默认使用 mysql_native_password 认证插件。对已存在的用户,你可能需要重新设置密码,使更改生效:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Li4444555635!';

3. 加载插件(如果确实没有加载)

如果你确认 MySQL 安装包含 mysql_native_password 插件,但因某些原因它没有加载,可以尝试手动加载插件(这在标准安装中很少需要):

INSTALL PLUGIN mysql_native_password SONAME 'auth_socket.so';

请注意,替换 'auth_socket.so' 为实际的插件文件名,这可能因操作系统和 MySQL 版本而异。

4. 重新安装或检查 MySQL 版本

如果以上步骤都无法解决问题,确保你的 MySQL 版本支持 mysql_native_password 认证插件。可能需要重新安装或升级 MySQL。 在操作前,建议备份所有重要数据和检查 MySQL 的兼容性信息确保版本支持你需要的特性。

http://www.lryc.cn/news/410557.html

相关文章:

  • Hive数据类型
  • OSI七层网络模型:构建网络通信的基石
  • MSYS2下载安装和使用
  • 机器学习中的决策树算法——从理论到实践完整指南
  • FFplay介绍及命令使用指南
  • php实现动态登录
  • Servlet2-HTTP协议、HttpServletRequest类、HttpServletResponse类
  • 探索数据的内在世界:sklearn中分层特征聚类标签的可视化技术
  • airtest定位方法
  • 排列组合 n*(n-1)*(n-m+1)
  • Python面试整理-数据处理和分析
  • 职业教育计算机网络综合实验实训室建设应用案例
  • 【Docomo】5G
  • Servlet详解(Servlet源码)
  • 仓颉--接收控制台输入
  • 数据库设计效率提高的5大注意事项
  • C语言笔试题(一)
  • 轻松实现远程智能交互:OriginBot与钉钉和GPT4o的集成指南
  • Qt题目知多少-1
  • nginx的反向代理和负载均衡(seventeen day)
  • BES编译SDK中遇到的perl问题
  • 【康复学习--LeetCode每日一题】3111. 覆盖所有点的最少矩形数目
  • Django实战:开启数字化任务管理的新纪元
  • 史上最全网络安全面试题+答案
  • Python 爬虫入门(五):使用 lxml 解析网页
  • 阿里云RDS到亚马逊云RDS的实时数据同步方案详解
  • 《LeetCode热题100》---<滑动窗口篇两道>
  • Python学习计划——9.1多线程编程
  • 借助 NGINX 对本地的 Kubernetes 服务进行自动化的 TCP 负载均衡
  • 基于python的大学学生影响力分析系统设计与实现