zoukankan      html  css  js  c++  java
  • mysql错误:this authentication plugin is not supported

    this authentication plugin is not supported

    应用程序连接mysql docker一直报错:this authentication plugin is not supported。
    google发现,原来是mysql新版本(8.0以上)将root用户使用的plugin更新成caching_sha2_password。
    登录mysql输入如下命令可以看到:

    mysql> select user,plugin from mysql.user;
    +------------------+-----------------------+
    | user | plugin |
    +------------------+-----------------------+
    | root | caching_sha2_password |
    | mysql.infoschema | mysql_native_password |
    | mysql.session | mysql_native_password |
    | mysql.sys | mysql_native_password |
    | root | caching_sha2_password |
    +------------------+-----------------------+

    解决办法有:
    (1)降级,使用老版本mysql。
    (2)将root的plugin改成mysql_native_password。
    这里改成:

    ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘root’;

    这行代码有两层含义,第一:修改root的密码为’root’,摒弃原来的旧密码。第二:使用mysql_native_password对新密码进行编码。

    然后再启动应用,还是一样报错。再看mysql.user,发现还有一个host”%”的root用户:


    mysql> select host,user,plugin from mysql.user;
    +-----------+------------------+-----------------------+
    | host | user | plugin |
    +-----------+------------------+-----------------------+
    | % | root | caching_sha2_password |
    | localhost | mysql.infoschema | mysql_native_password |
    | localhost | mysql.session | mysql_native_password |
    | localhost | mysql.sys | mysql_native_password |
    | localhost | root | mysql_native_password |
    +-----------+------------------+-----------------------+
    5 rows in set (0.00 sec)

    将这个用户也改了:
    ALTER USER ‘root’@’%’ IDENTIFIED WITH mysql_native_password BY ‘root’;
    再看:


    mysql> select host,user,plugin from mysql.user;
    +-----------+------------------+-----------------------+
    | host | user | plugin |
    +-----------+------------------+-----------------------+
    | % | root | mysql_native_password |
    | localhost | mysql.infoschema | mysql_native_password |
    | localhost | mysql.session | mysql_native_password |
    | localhost | mysql.sys | mysql_native_password |
    | localhost | root | mysql_native_password |
    +-----------+------------------+-----------------------+

    改成功了,再启动应用,报错:
    this user requires mysql native password authentication
    在连接mysql的url上加上?allowNativePasswords=true,这次正常了。
    ---------------------

  • 相关阅读:
    codeforces 1C(几何题)
    poj 1015 Jury Compromise
    poj 1466 计算直线的交点数
    poj 1228 凸包第一题
    2012 MUTC 3 总结
    用优先队列优化Dij的一个代码
    有关排序时,上移,下移的处理思路
    有关缓存的思考
    python备份文件2 分类: python 20130315 15:16 233人阅读 评论(0) 收藏
    lambda表达式使用方法详解 分类: python 20130315 10:58 396人阅读 评论(0) 收藏
  • 原文地址:https://www.cnblogs.com/mafeng/p/10122582.html
Copyright © 2011-2022 走看看