Linux MySQL客户端的error 2059

2024-04-23 17:58

本文主要是介绍Linux MySQL客户端的error 2059,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

“error 2059: Authentication plugin ‘caching_sha2_password’ cannot be loaded”

 

 

 

问题描述

在 VMware 虚拟机的客户机 CentOS7 里面安装运行有 Docker 的 MySQL 8.0,由于当前 CentOS7 默认的 MySQL 客户端版本太低(5.5.60)(低版本的客户端认 mysql_native_password 认证插件,而高版本认 caching_sha2_password 插件) ,导致连接服务器时出现以下的错误:

 

 

1

2

error 2059: Authentication plugin 'caching_sha2_password' cannot be loaded: /usr/lib64/mysql/plugin/caching_sha2_password.so: cannot open shared object file: No such file or directory

 

 

解决办法

  1. 用高版本的 MySQL,或者进入该 Docker 容器,登录 MySQL 服务器。
  2. 执行 MySQL shell 命令查看服务器的版本:

     

     

    1

    2

    > select version();

     

     

    执行结果:

     

     

    1

    2

    3

    4

    5

    6

    7

    +-----------+

    | version() |

    +-----------+

    | 8.0.16    |

    +-----------+

    1 row in set (0.00 sec)

     

     

  3. 查看当前默认的密码认证插件:

     

     

    1

    2

    > show variables like 'default_authentication_plugin';

     

     

     

     

    1

    2

    3

    4

    5

    6

    7

    +-------------------------------+-----------------------+

    | Variable_name                 | Value                 |

    +-------------------------------+-----------------------+

    | default_authentication_plugin | caching_sha2_password |

    +-------------------------------+-----------------------+

    1 row in set (0.01 sec)

     

     

  4. 查看当前所有用户绑定的认证插件:

     

     

    1

    2

    > select host,user,plugin from mysql.user;

     

     

     

     

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    +-----------+------------------+-----------------------+

    | host      | user             | plugin                |

    +-----------+------------------+-----------------------+

    | %         | root             | caching_sha2_password |

    | localhost | healthchecker    | caching_sha2_password |

    | localhost | mysql.infoschema | caching_sha2_password |

    | localhost | mysql.session    | caching_sha2_password |

    | localhost | mysql.sys        | caching_sha2_password |

    +-----------+------------------+-----------------------+

    5 rows in set (0.00 sec)

     

     

  5. 假如想更改 root 用户的认证方式

     

     

    1

    2

    3

    4

    5

    6

    7

    8

    9

    # 修改加密规则

    > ALTER USER 'root'@'%' IDENTIFIED BY 'root' PASSWORD EXPIRE NEVER;

    # 更新用户密码

    > ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

    # 赋予 root 用户最高权限

    > grant all privileges on *.* to root@'%' with grant option;

    # 刷新权限

    > flush privileges;

     

     

    完成解决方案。
    注意:在这之后,将不再支持以下的权限授予语句:

 

 

1

2

grant all privileges on *.* to root@'%' identified by '123456' with grant option;

 

 

参考资料:

MySQL 8.0报错:error 2059: Authentication plugin ‘caching_sha2_password’ cannot be loaded)

这篇关于Linux MySQL客户端的error 2059的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/929497

相关文章

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文