zoukankan      html  css  js  c++  java
  • navicat for mysql 链接时报错:1251-Client does not support authentication protocol requested by server

    客户端使用navicat for mysql。本地安装了mysql 8.0.18。但是在链接的时候提示:

     主要原因是mysql服务器要求的认证插件版本与客户端不一致造成的。

    mysql8.0以后的使用的plugin是caching_sha2_password,必须使用支持此插件的客户端版本。

    plugin的作用之一就是处理后的密码格式和长度是不一样的,类似于使用MD5加密和使用base64加密一样对于同一个密码处理后的格式是不一样的。

    解决方法是将root的plugin改成mysql_native_password。相当于降了一级。

    1、登录数据库 mysql -u root -p

    2、查看用户信息

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

    host为 % 表示不限制ip; localhost表示本机使用 ; plugin非mysql_native_password 则需要修改密码

    3、修改用户密码

    ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你设置的密码'; 

    更新用户的密码 root用户密码为newpassword或者改成其他密码都可以

    注意#:可能会报错ERROR 1396 (HY000): Operation ALTER USER failed for ‘root’@’%’,需要注意你上图列表中 user 项中的 root 是% 还是localhost; 如果是localhost则将上述语句改成ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你设置的密码';

    配置成功!!!!!

  • 相关阅读:
    nginx安装配置: configure命令
    nginx最简安装
    进程上下文切换
    九卷读书:《操作系统设计与实现》读书笔记
    计算机存储器的层次结构
    线程,进程和并发
    理解Flight框架核心
    Ubuntu16.04安装QQ机器人
    微信支付解决方案
    springboot +nginx +freemarker 模板的简单集成
  • 原文地址:https://www.cnblogs.com/h-z-y/p/14266514.html
Copyright © 2011-2022 走看看