MySQL 8 连接报错:Public Key Retrieval is not allowed

错误日志

复制代码
2025-11-17 10:11:08 ERROR 21740 --- [论坛系统] [eate-1546318093] com.alibaba.druid.pool.DruidDataSource   : 
create connection SQLException, url: jdbc:mysql://localhost:3306/forum_db?useSSL=false&serverTimezone=UTC, 
errorCode 0, state 08001

java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed

问题描述

Spring Boot 在启动项目时,数据库连接池(Druid)无法创建 MySQL 连接,抛出:

复制代码
Public Key Retrieval is not allowed

出现原因

MySQL 8 默认用户认证方式为 caching_sha2_password

当客户端(JDBC)尝试连接数据库时,需要从服务器获取 RSA 公钥。如果 MySQL 未允许客户端获取公钥,就会报:

复制代码
Public Key Retrieval is not allowed

Spring Boot + MySQL 8 在未加入某些参数时就会发生此问题。

解决方法(推荐)

application.yml 的数据源 URL 中加入:

复制代码
allowPublicKeyRetrieval=true

✔ 正确配置示例:

yaml 复制代码
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/forum_db?useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true
    username: root
    password: 密码

可选解决方案(不推荐)

将 MySQL 用户认证方式改成旧版本的 mysql_native_password

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

不推荐用此方式,因为安全性较低。


最终结论

这是 MySQL 8 的认证机制导致的连接问题,通过在 JDBC URL 中加入:

复制代码
allowPublicKeyRetrieval=true

即可解决,属于常见的 MySQL 8 JDBC 连接参数问题。


相关推荐
invicinble15 分钟前
对于mysql层对sql层面的知识体系的理解和把握
数据库·sql·mysql
2301_7903009617 分钟前
用Matplotlib绘制专业图表:从基础到高级
jvm·数据库·python
DFT计算杂谈41 分钟前
VASP+PHONOPY+pypolymlpj计算不同温度下声子谱,附批处理脚本
java·前端·数据库·人工智能·python
数据知道43 分钟前
PostgreSQL核心原理:为什么数据库偶尔会卡顿?
数据库·postgresql
Nandeska1 小时前
14、MySQL基于GTID的数据同步
数据库·mysql
Mr_Xuhhh1 小时前
MySQL表的内连接与外连接详解
java·前端·数据库
kyle-fang1 小时前
阿里云服务器部署MySQL
服务器·mysql·阿里云
l1t1 小时前
DeepSeek辅助总结postgresql wiki提供的数独求解器
数据库·sql·postgresql
appearappear1 小时前
大数据量处理
数据库
万行1 小时前
SQL进阶&索引篇
开发语言·数据库·人工智能·sql