Mysql 报错 “Public Key Retrieval is not allowed”

报错 "Public Key Retrieval is not allowed" 出现的原因和之前分析的一样:MySQL 用户使用了 caching_sha2_password 认证,而 DBeaver 默认不允许自动获取公钥。

解决方法:


方法 A:在 DBeaver 中修改连接属性

  1. 点击 编辑驱动设置 → 驱动属性(Driver Properties)

  2. 找到或新增属性:

    • allowPublicKeyRetrievaltrue
    • useSSLfalse(如果你不使用 SSL)
  3. 保存后再测试连接。

示例 JDBC URL 形式(DBeaver 可以自动拼接):

ini 复制代码
jdbc:mysql://10.0.71.31:3306/dbname?allowPublicKeyRetrieval=true&useSSL=false

方法 B:修改 MySQL 用户认证方式

如果你可以修改数据库:

sql 复制代码
ALTER USER 'dzm'@'%' IDENTIFIED WITH mysql_native_password BY '你的密码';
FLUSH PRIVILEGES;

然后在 DBeaver 里直接连接即可,无需修改额外参数。


💡 总结:

  • 最快解决 :在 DBeaver 驱动属性里加 allowPublicKeyRetrieval=true
  • 更安全 :把用户改成 mysql_native_password
相关推荐
P-surp2 小时前
mysql 数据库 批量库 迁移、恢复
数据库·mysql
繁星星繁2 小时前
【Mysql】数据库的操作
数据库·mysql·oracle
sinat_363954233 小时前
Canal-deployer1.1.8监听mysql数据变化(windows)
windows·mysql
sc.溯琛3 小时前
MySQL 性能优化核心:索引创建与管理实战指南
数据库·mysql·性能优化
ZePingPingZe4 小时前
MySQL与Spring,事务与自动提交有什么关系?
mysql·spring
q_19132846954 小时前
基于SpringBoot2+Vue2的企业合作与活动管理平台
java·vue.js·经验分享·spring boot·笔记·mysql·计算机毕业设计
凌冰_4 小时前
JAVA与MySQL实现银行管理系统
java·开发语言·mysql
北友舰长5 小时前
基于Springboot+thymeleaf图书管理系统的设计与实现【Java毕业设计·安装调试·代码讲解】
java·spring boot·mysql·课程设计·图书管理·b/s·图书
麦麦鸡腿堡6 小时前
MySQL数据库操作指令
数据库·mysql