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

在使用Docker安装MySQL 8.0后,发现Navicat 11无法连接,报caching_sha2_password错误。原因是MySQL8.0更改了加密规则。解决方法包括升级Navicat至最新版或修改MySQL用户密码加密规则为mysql_native_password。执行后,Navicat成功连接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

年后一直在忙的工作终于到一段落了,闲下来终于有时间学习新技术了,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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值