注:此文章是在mysql8版本的前提下编写的。
在我们使用springcloud在连接mysql数据库时,有时会碰到如下这种异常:
Exception in thread "main" com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1116)
at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:344)
at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2332)
at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2369)
at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2153)
at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:792)
at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:525)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:381)
at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:305)
at java.sql.DriverManager.getConnection(DriverManager.java:579)
at java.sql.DriverManager.getConnection(DriverManager.java:243)
at javaapplication3.JavaApplication3.main(JavaApplication3.java:32)
为此我上网查了不少资料,在这里小总结一下:
1. 连接url是否正确(自己看看useSSL是否为false):
2.数据库服务是否打开:
找到MySql服务:
3.网上最多解决的等待时间问题:(wait_timeout)
我使用的mysql版本为 8.0.27 ,在用网上的修改my.ini配置文件时 mysql会直接报错,启动不了,即使临时修改wait_timeout时间,也是一样会报错。目前 mysql8版本我找不到修改的方法。(也许是我笨蛋)
4.在依赖导入时mysql版本是否正确:
上方的方法都实践过后如果依然报错,那么有极大可能是你在pom.xml文件中导入的mysql驱动与你自身安装的mysql版本不一致。
当写的项目是从外面copy进来的,那么就要仔细看mysql版本了,打开父工程的pom.xml文件:
可以看到版本不一致:
改成自身的版本:
子工程的版本都是从父工程中获取的,只要改这里就好了,版本对应上了,就没有再报错了。
如果帮到了你,还请留下一个小小的赞QAQ
文章来源地址https://www.toymoban.com/news/detail-794004.html
文章来源:https://www.toymoban.com/news/detail-794004.html
到了这里,关于已解决The last packet sent successfully to the server was 0 milliseconds ago. The driver has not receiv的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!