[报错解决]Communications link failure

报错

主机IDEA项目连接虚拟机的数据库报错。

主要报错信息有:

com.mysql.cj.jdbc.exceptions.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.

.........

先排查基本问题。端口开启且没被占用、防火墙关闭了、数据库开启了,IDEA导出的Jar包在虚拟机中也没问题,所以只能是主机IDEA这边的项目代码或者是IDEA本身的问题。

整段报错信息有14万字。

只帖取部分具体报错信息。

具体报错:

2024-05-05 14:24:04.558 ERROR 4900 --- main com.alibaba.druid.pool.DruidDataSource : init datasource error, url: jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC

com.mysql.cj.jdbc.exceptions.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 com.mysql.cj.jdbc.exceptions.SQLError.createCommunicationsException(SQLError.java:174) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:64) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:835) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:455) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:240) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:199) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:148) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterAdapter.connection_connect(FilterAdapter.java:785) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterEventAdapter.connection_connect(FilterEventAdapter.java:38) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:142) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterAdapter.connection_connect(FilterAdapter.java:785) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:142) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.stat.StatFilter.connection_connect(StatFilter.java:211) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.filter.FilterChainImpl.connection_connect(FilterChainImpl.java:142) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1454) ~druid-1.0.28.jar:1.0.28

at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1516) ~druid-1.0.28.jar:1.0.28

具体报错:

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.

at jdk.internal.reflect.GeneratedConstructorAccessor42.newInstance(Unknown Source) ~na:na

at java.base/jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~na:na

at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:499) ~na:na

at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:480) ~na:na

at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:61) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:105) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.exceptions.ExceptionFactory.createException(ExceptionFactory.java:151) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.exceptions.ExceptionFactory.createCommunicationsException(ExceptionFactory.java:167) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.protocol.a.NativeSocketConnection.connect(NativeSocketConnection.java:91) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.NativeSession.connect(NativeSession.java:152) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:955) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:825) ~mysql-connector-java-8.0.16.jar:8.0.16

... 14 common frames omitted

Caused by: java.net.ConnectException: Connection refused: connect

at java.base/sun.nio.ch.Net.connect0(Native Method) ~na:na

at java.base/sun.nio.ch.Net.connect(Net.java:579) ~na:na

at java.base/sun.nio.ch.Net.connect(Net.java:568) ~na:na

at java.base/sun.nio.ch.NioSocketImpl.connect(NioSocketImpl.java:588) ~na:na

at java.base/java.net.SocksSocketImpl.connect(SocksSocketImpl.java:327) ~na:na

at java.base/java.net.Socket.connect(Socket.java:633) ~na:na

at com.mysql.cj.protocol.StandardSocketFactory.connect(StandardSocketFactory.java:155) ~mysql-connector-java-8.0.16.jar:8.0.16

at com.mysql.cj.protocol.a.NativeSocketConnection.connect(NativeSocketConnection.java:65) ~mysql-connector-java-8.0.16.jar:8.0.16

... 17 common frames omitted

进程已结束,退出代码1

解决

1.找到项目的application-dev.yml配置文件,找到url

复制代码
url: jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC

把其中的localhost修改为MySQL所在服务器的ip地址

修改完毕后如下图:

2.同样是application-dev.yml配置文件,找到username和password

复制代码
username: root
password:

把数据库密码填入password

修改完毕后如下图:

相关推荐
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第87题】【Mysql篇】第17题:分布式事务的实现原理?
java·数据库·分布式·mysql·面试
来杯@Java7 小时前
图书管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·mybatis·课程设计
卷毛的技术笔记7 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程
编程大师哥7 小时前
匿名函数 lambda + 高阶函数
java·python·算法
東雪木8 小时前
多线程与并发编程 专属复习笔记
java·开发语言·笔记·java面试
adrninistrat0r8 小时前
Java调用链MCP分析工具
java·python·ai编程
噜噜噜阿鲁~8 小时前
python学习笔记 | 11.3、面向对象高级编程-多重继承
java·开发语言
春生野草9 小时前
反射、Tomcat执行
java·开发语言
_日拱一卒9 小时前
LeetCode:207课程表
java·数据结构·算法·leetcode·职场和发展
飞翔中文网10 小时前
Java学习笔记之抽象类与接口(设计思想)
java·笔记·学习