Navicat 无法连接MySQL8.0的caching_sha2_password问题

前言

年后一直在忙的工作终于到一段落了,闲下来终于有时间学习新技术了,docker 容器技术这么火爆,利用docker 安装一个mysql 8.0, 遇到Navicat 无法连接MySQL8.0的caching_sha2_password问题,查找资料解决。

现象

mysql 8版本,Navicat 11 版本,通过docker 安装一个mysql8之后,设置密码,进入容器内部访问数据库都没问题。但是在外部通过Navicat 11连接的时候却无法连接,报 caching_sha2_password 的错误。

原因

经过查找官方文档,了解到mysql8 之前的版本中加密规则是 mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password,应该是这个原因导致的无法连接的错误。

解决办法

1. 升级navicat驱动,安装最新版navicat,应该支持caching_sha2_password加密插件。

2.把mysql用户登录密码加密规则还原成mysql_native_password

> mysql -uroot -p (进入数据库)
mysql> use mysql; (操作mysql库)
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456' PASSWORD EXPIRE NEVER;
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
mysql> ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
mysql> FLUSH PRIVILEGES;   

操作完之后回到Navicat ,连接成功!

原创文章 29 获赞 81 访问量 1万+

猜你喜欢

转载自blog.csdn.net/cuixhao110/article/details/105529451