com.mysql.jdbc.exceptions.jdbc4.communicationsexception:通信链路故障

42fyovps  于 2021-07-12  发布在  Spark
关注(0)|答案(23)|浏览(536)

我正在努力让我的数据库和我的java程序对话。
有人能给我一个使用jdbc的快速而肮脏的示例程序吗?
我得到了一个相当惊人的错误:

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:39)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:409)
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1122)
    at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2260)
    at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:787)
    at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:49)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:409)
    at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:357)
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:285)
    at java.sql.DriverManager.getConnection(DriverManager.java:582)
    at java.sql.DriverManager.getConnection(DriverManager.java:207)
    at SqlTest.main(SqlTest.java:22)
Caused by: 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:39)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:409)
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1122)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:344)
    at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2181)
    ... 12 more
Caused by: java.net.ConnectException: Connection refused
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
    at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:432)
    at java.net.Socket.connect(Socket.java:529)
    at java.net.Socket.connect(Socket.java:478)
    at java.net.Socket.<init>(Socket.java:375)
    at java.net.Socket.<init>(Socket.java:218)
    at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:256)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:293)
    ... 13 more

测试文件的内容:

import com.mysql.jdbc.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class SqlTest {

    public static void main(String [] args) throws Exception {
        // Class.forName( "com.mysql.jdbc.Driver" ); // do this in init
        // // edit the jdbc url 
        Connection conn = DriverManager.getConnection( 
            "jdbc:mysql://localhost:3306/projects?user=user1&password=123");
        // Statement st = conn.createStatement();
        // ResultSet rs = st.executeQuery( "select * from table" );

        System.out.println("Connected?");
    }
}
qnzebej0

qnzebej016#

所以,你有一个
com.mysql.jdbc.exceptions.jdbc4.communicationsexception:通信链路故障
java.net.connectexception:连接被拒绝
我引用了这个答案,其中还包含一个循序渐进的mysql+jdbc教程:
如果你得到一个 SQLException: Connection refused 或者 Connection timed out 或者mysql特定的 CommunicationsException: Communications link failure ,则表示数据库根本无法访问。这可能有以下一个或多个原因:
jdbc url中的ip地址或主机名错误。
本地dns服务器无法识别jdbc url中的主机名。
jdbc url中缺少端口号或端口号错误。
数据库服务器已关闭。
数据库服务器不接受tcp/ip连接。
数据库服务器的连接已用完。
java和db之间的某些东西正在阻塞连接,例如防火墙或代理。
要解决其中一个问题,请遵循以下建议:
验证和测试 ping .
刷新dns或改用jdbc url中的ip地址。
验证基于 my.cnf mysql数据库。
启动数据库。
验证mysqld是否在没有 --skip-networking option .
重新启动db并相应地修复代码,以关闭数据库中的连接 finally .
禁用防火墙和/或配置防火墙/代理以允许/转发端口。

另请参见:

在基于servlet的应用程序中,我应该如何连接到jdbc数据库/数据源?
在多线程系统中使用静态java.sql.connection示例安全吗?

66bbxpm5

66bbxpm517#

我得到了同样的错误,因为我试图运行我的程序而不启动mysql服务器。
启动mysql服务器后,一切正常。

vbkedwbf

vbkedwbf18#

我可能在这里找错了树,但是你的异常似乎表明你的mysql服务器不可用。
线程“main”com.mysql.jdbc.exceptions.jdbc4.communicationsexception中出现异常:通信链路故障上次成功发送到服务器的数据包是0毫秒前的。驱动程序尚未从服务器接收到任何数据包。在。。。
如果你尝试(从终点站)会发生什么

mysql -u username -p

系统将提示您输入与用户名关联的密码。在您给出正确的密码之后,mysql客户端是否连接?
如果没有,您可能必须从首选项启动mysql。您还可以将其设置为在启动时运行。

t9eec4r0

t9eec4r019#

我已经有同样的问题好几个小时了。我用的是mamp服务器
不要使用localhost:[apache port],而是使用mysql端口。
下面是mamp服务器的默认mysql端口。

String url = "jdbc:mysql://localhost:8889/db_name";

Connection conn = DriverManager.getConnection(url, dbUsername, dbPassword);
nr7wwzry

nr7wwzry20#

在我的情况下,结果是 mysql-connector-java 太老了。
在我的演示中,我使用 mysql-connector-java 这样地:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.9</version>
</dependency>

但在开发环境中,我使用以下方法:

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.31</version>
</dependency>

我的mysql版本是5.1.48(是的,它是旧的,只是为了模仿产品版本)。所以我遇到了同样的错误。
既然找到了原因,也就找到了解决办法。匹配版本!

hwamh0ep

hwamh0ep21#

这个 com.mysql.jdbc.exceptions.jdbc4.CommunicationsException 如果数据库连接长时间处于空闲状态,则会发生异常。
此空闲连接在 connection.isClosed(); 但如果我们尝试执行语句,那么它将引发此异常,所以我建议使用数据库池。

mrfwxfqh

mrfwxfqh22#

当java出堆时,我发现了这个异常。如果我尝试在ram中放入许多数据项—首先我捕获“通信链路故障”,然后捕获“outofmemoryerror”。
我记录了它,我减少了内存消耗(删除1/2的数据),一切正常。

laik7k3q

laik7k3q23#

在我的例子中,我需要将localhost替换为实际的数据库服务器ip地址
而不是

Connection con = DriverManager.getConnection(
 "jdbc:mysql://localhost:3306/DBname", "root", "root");

我需要

Connection con = DriverManager.getConnection(
 "jdbc:mysql://192.100.0.000:3306/DBname", "root", "root");

相关问题