数据库连接错误 GlobalConfigUtils setMetaData Fail

记录一下mysql的一次错误排查

1. 情景再现

  • 项目为springboot+mybatis项目

  • 错误发生在启动项目时,之前该项目可以正常启动,没有更改数据库相关的配置

  • 异常信息为:

Caused by: com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: Error: GlobalConfigUtils setMetaData Fail !

2. 查找原因

首先这个报错是跟数据库配置有关,问题发生在连接mysql数据库时。

但是具体是哪个配置出了问题我们并不知道,而这个报错是一个springboot给我们抛出来的异常,很难定位到具体是因为什么原因导致的。

通过debug发现错误发生在:MybatisSqlSessionFactoryBean.class:367

        Connection connection = ((DataSource)AopUtils.getTargetObject(this.dataSource)).getConnection();

在idea debug 模式的计算器中,evaluate一下上面这行语句就可以看到连接数据库过程中的详细报错为:

Public Key Retrieval is not allowed

3. 解决问题

解决办法: 在数据库url后面添加allowPublicKeyRetrieval=true

解决办法参考的以下博客:
MySQL 8.0 Public Key Retrieval is not allowed 错误的解决方法

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值