项目场景
一个老项目刚刚升级到jdk17,项目依赖flyway,在本地从空库启动正常,但是发布到测试环境报错
问题描述
发布到测试环境报错:
com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure
检查了数据库连接和配置都没发现问题。
原因分析:
于是对数据库和代码做了交叉验证,发现只有升级后的代码连接测试的数据库才会出现这个问题。
查找了跟这个报错相关的资料很多都说是配置错误。但是经过一番尝试对我这种情况无效。应该不是配置的问题。
数据库的配置也做了尝试,没有发现问题原因。
然后排查了一下连接池问题,排除druid的连接池,这次启动正常。问题的原因应该是druid有问题。既然druid的配置跟之前是一样的,之前没问题,现在有问题,那很可能是druid的依赖有问题。
解决方案:
经过尝试,将druid的版本从1.2.x降到1.1.17,启动成功。问题的根本原因并没有找到,猜测是1.2.x和mysql5.7之间有未知的适配问题。