【转载】 Springboot 2.3.5 连接 Mysql8报错 The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received

转自:https://blog.csdn.net/ponxbin/article/details/80608040

网上说的什么修改的方法对我没有用

诸如此类:

1· 修改my.ini bind-address = 127.0.0.1 为 bind-address = 0.0.0.0 使非本地网络可以访问数据库

2· 检查防火墙是否有开放3306端口

3· 网上广为流传的86400秒超时 回收机制 并不和我遇到的问题一致,这种问题是在程序运行过程中因为我们使用的连接池不知道连接被回收了所以报出的异常,解决方案可以是修改连接池配置或修改mysql空闲超时时间配置。

以上方法均没用,主要是mysql和驱动版本的问题

我的mysql是8.0,驱动也是8.x最新的;

Class.forName("com.mysql.cj.jdbc.Driver");

url = "jdbc:mysql://localhost:3306/jnditest?serverTimezone=GMT&useSSL=false";//数据库的路径

主要是红色字体方面,serverTimezone缺失是很容易从错误找出来的,但是重点是useSSL=false,这个从错误提示是看不出来的,它有个很重要的作用是使用JDBC跟你的数据库连接的时候,你的JDBC版本与MySQL版本不兼容,MySQL的版本更高一些,在连接语句后加上“useSSL=‘true’” ,就可以连接到数据库了。更高版本。但如果是兼容版本的话就会出错。

我试了改成true的确又出现了这个问题。

posted @ 2021-08-06 11:47  夏秋初  阅读(918)  评论(0)    收藏  举报