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 连接参数问题。


相关推荐
不剪发的Tony老师29 分钟前
Noir:一款键盘驱动的现代化数据库管理工具
数据库·sql
.柒宇.2 小时前
MySQL双主同步
linux·数据库·mysql·docker
Trouvaille ~2 小时前
【MySQL篇】数据类型:存储数据的基础
android·数据库·mysql·adb·字符集·数据类型·基础入门
一 乐2 小时前
酒店预订|基于springboot + vue酒店预订系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·酒店预订系统
光泽雨3 小时前
UNION 和 UNION ALL 作用
数据库·sql
heimeiyingwang3 小时前
【架构实战】SQL调优实战:从执行计划到索引优化
数据库·sql·架构
恼书:-(空寄3 小时前
分库分表风险应对手册(生产实战版)
数据库·分库分表
XDHCOM4 小时前
ORA-06521: PL/SQL映射函数错误,权威解析Oracle报错故障修复与远程处理方案
数据库·sql·oracle
仲芒4 小时前
[24年单独笔记] MySQL 常用的 DDL 命令
笔记·mysql·oracle
数厘4 小时前
2.11 约束的使用(主键、外键、非空、唯一、默认值约束)
sql·mysql·数据分析