【已解决】1251 您所在的位置:网站首页 sqlyog连接mysql数据库错误1251 【已解决】1251

【已解决】1251

2023-11-20 07:54| 来源: 网络整理| 查看: 265

远程连接docker容器中的mysql8.0数据库时出现连接不上 👀1. 场景:👀2. 原因分析:🚀3. 解决:3.1 方法一3.2 方法二

报错信息

1251 - Client does not support authentication protocol requested by server; consider upgrading MySQL client

在这里插入图片描述

👀1. 场景:

远程连接docker容器中的mysql8.0数据库时出现连接不上,mysql8.0版本之前没有该问题.

👀2. 原因分析:

​ 出现1251的主要原因是由于mysql版本的问题,mysql8.0版本,与mysql8.0以下版本的加密方式不同,导致错误产生。

MySql 8.0.11 换了新的身份验证插件(caching_sha2_password),而原来的身份验证插件为(mysql_native_password)。

​ 而客户端工具Navicat Premium12 中找不到新的身份验证插件(caching_sha2_password),因此报上面的错,所以我们将mysql用户使用的 登录密码加密规则还原成 mysql_native_password,即可登陆成功。

🚀3. 解决: 3.1 方法一

修改root加密方式

​ 1) 查看root或其他用户信息的加密方式

[root@centos7 ~]# mysql -u root -p #登陆mysql mysql> use mysql; # 切换mysql数据库 mysql> select user,plugin from user where user='root'; #查看root的加密方式

在这里插入图片描述

​ 2) 改变加密方式

alter user 'root'@'%' identified with mysql_native_password by '123456';

在这里插入图片描述

mysql> select user,plugin from user where user='root';

在这里插入图片描述

​ 通过上面两步,即可解决问题

在这里插入图片描述

3.2 方法二

添加用户,同时设置登陆加密方式为mysql_native_password,并且给它远程访问权限,完成后这个用户也可以访问.

添加远程登录用户 CREATE USER 'mjh'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; GRANT ALL PRIVILEGES ON *.* TO 'mjh'@'%';


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有