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

lskq00tm  于 2021-06-23  发布在  Mysql
关注(0)|答案(23)|浏览(419)

我正在努力让我的数据库和我的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?");
    }
}
cyvaqqii

cyvaqqii1#

我也有同样的问题,下面是如何解决的:
jsp正在调用servlet中尚未定义的属性。
我有两个列名,通过它们传递给一个对象 ResultSet (getString("columnName")) 与我数据库中的列名不匹配。
我不确定哪一个解决了这个问题,但它起了作用。另外,请确保您创建了一个新的 Statement 以及 ResultSet 对于每个表查询。

o7jaxewo

o7jaxewo2#

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

ewm0tg9j

ewm0tg9j3#

刚刚经历过。
必须使其工作:(这可以放在静态块初始化)

static{ // would have to be surrounded by try catch
    Class.forName("com.mysql.jdbc.Driver");   // this will load the class Driver
}

通过以下方式获得连接:

conn = DriverManager.getConnection(DBURL,<username>,<password>);

而不是指定登录参数

Connection conn = DriverManager.getConnection( "jdbc:mysql://localhost:3306/projects?user=user1&password=123");

当做。

64jmpszr

64jmpszr4#

我用一种简单的方法解决了这个问题,这对我很有用。我遇到了seme问题“com.mysql.jdbc.exceptions.jdbc4.communicationsexception:communications link failure”。在我的db.properties文件中,我有:url:jdbc:mysql://localhost:90/mydb,只删除了端口url,结果是这样的url:jdbc:mysql://localhost/mydb 这对我很有效。

col17t5w

col17t5w5#

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

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

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

blpfk2vs6#

试着改变 localhost127.0.0.1 .
localhost将解析为 ::1 . 默认情况下mysql不能通过ipv6连接。
这是 telnet localhost 3306 :

$ telnet localhost 3306
Trying ::1...

mysql服务器没有响应。
当然,请确保您的mysql服务器正在运行。

6rqinv9w

6rqinv9w7#

请在/etc/mysql/my.cnf文件中更新您的ip地址

bind-address  = 0.0.0.0

重新启动mysql deamon和mysql服务。

vdgimpew

vdgimpew8#

远程调用mysql
将远程用户添加到mysql,例如ip=remoteip:

mysql -u xxxx -p //local coonection to mysql
mysql> GRANT ALL PRIVILEGES ON *.* TO 'theNewUser'@'remoteIP' IDENTIFIED BY 'passWord';
//Query OK, 0 rows affected (xx sec)
mysql> FLUSH PRIVILEGES;
//Query OK, 0 rows affected

允许远程访问mysql(默认情况下不允许所有外部调用):

Edit 
/etc/mysql/mysql.conf.d/mysqld.cnf    or    /etc/mysql/my.cnf
Change line:  bind-address = 127.0.0.1   to
              bind-address = 0.0.0.0
Restart Mysql: /etc/init.d/mysql restart

对于最新版本的jdbc驱动程序,jdbc:

jdbc.url='jdbc:mysql://remoteIP:3306/yourDbInstance?autoReconnect=true&amp;useUnicode=true&amp;useJDBCCompliantTimezoneShift=true&amp;useLegacyDatetimeCode=false&amp;serverTimezone=UTC'
jdbc.user='theNewUser'
enxuqcxy

enxuqcxy9#

从mysql下载mysql-jdbc-type-4-treiber(例如,从mysql-connector-java-5.1.11.zip下载mysql-connector-java-5.1.11-bin.jar)。
您需要在编译和运行时在类路径中包含驱动程序jar。

Class.forName( "com.mysql.jdbc.Driver" ); // do this in init
// edit the jdbc url 
Connection conn = DriverManager.getConnection( "jdbc:mysql://MyDbComputerNameOrIP:3306/myDatabaseName", username, password );
Statement st = conn.createStatement();
ResultSet rs = st.executeQuery( "select * from table" );
vktxenjb

vktxenjb10#

如果您更改了端口,则会出现这样的错误“com.mysql.jdbc.exceptions.jdbc4.communicationexception:communications link failure”,请检查您的端口号

xn1cxnb4

xn1cxnb411#

如果java试图通过ssl连接到mysql,但出现了问题,也可能会发生这个错误(在我的例子中,我将payara server 5.193.1连接池配置为mysql。)
有人建议设置 useSSL=false . 但是,由于连接器/j版本 8.0.13 ,该设置已弃用。以下是mysql connector/j 8.0配置属性的摘录:

SSL模式

默认情况下,网络连接是ssl加密的;此属性允许关闭安全连接,或选择不同的安全级别。允许以下值: DISABLED -建立未加密的连接; PREFERRED -(默认)如果服务器启用了加密连接,则建立加密连接,否则返回到未加密连接; REQUIRED -如果服务器启用了安全连接,则建立安全连接,否则失败; VERIFY_CA -就像 REQUIRED 但是,根据配置的证书颁发机构(ca)证书另外验证服务器tls证书; VERIFY_IDENTITY -就像 VERIFY_CA ,但还要验证服务器证书是否与尝试连接的主机匹配。
此属性替换了不推荐使用的旧属性 useSSL , requireSSL ,和 verifyServerCertificate ,但仍被接受,但转化为 sslMode 如果 sslMode 未显式设置: useSSL=false 已翻译为 sslMode=DISABLED ; {"useSSL=true", "requireSSL=false", "verifyServerCertificate=false"} 已翻译为 sslMode=PREFERRED ; {"useSSL=true", "requireSSL=true", "verifyServerCertificate=false"} 已翻译为 sslMode=REQUIRED ; {"useSSL=true" AND "verifyServerCertificate=true"} 已翻译为 sslMode=VERIFY_CA . 没有等效的旧版设置 sslMode=VERIFY_IDENTITY . 请注意,对于所有服务器版本,默认设置 sslModePREFERRED ,它相当于 useSSL=true , requireSSL=false ,和 verifyServerCertificate=false ,这与连接器/j 8.0.12和早期版本在某些情况下的默认设置不同。对于继续使用旧属性并依赖其旧默认设置的应用程序,应进行复查。
如果出现以下情况,则忽略旧属性 sslMode 是显式设置的。如果没有 sslMode 或者 useSSL 的默认设置 sslMode=PREFERRED 应用。
违约: PREFERRED 自版本:8.0.13起
所以,在我的情况下,设置 sslMode=DISABLED 是我解决问题所需要的一切。这是在试验机上。但是对于生产,安全的解决方案是正确地配置java客户机和mysql服务器以使用ssl。
注意,通过禁用ssl,您可能还需要设置 allowPublicKeyRetrieval=true . (同样,从安全的Angular 来看,这不是一个明智的决定)。mysql connectionstring options中提供了更多信息:

允许公共检索

如果用户帐户使用 sha256_password 认证,传输过程中必须保护密码;tls是实现这一点的首选机制,但如果它不可用,则将使用rsa公钥加密。要指定服务器的rsa公钥,请使用 ServerRSAPublicKeyFile 连接字符串设置,或 AllowPublicKeyRetrieval=True 允许客户端自动从服务器请求公钥。请注意 AllowPublicKeyRetrieval=True 可能允许恶意代理执行mitm攻击以获取明文密码,因此默认情况下为false,必须显式启用。

nwlqm0z1

nwlqm0z112#

在我的情况下,结果是 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(是的,它是旧的,只是为了模仿产品版本)。所以我遇到了同样的错误。
既然找到了原因,也就找到了解决办法。匹配版本!

68bkxrlz

68bkxrlz13#

在我的例子中,我需要将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");
jtjikinw

jtjikinw14#

如果您正在使用 WAMP 或者 XAMP 安装mysql数据库的服务器。然后您必须显式地启动mysql服务器,否则它将显示 com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 连接数据库时

lymgl2op

lymgl2op15#

当我在my.ini和php.ini文件中将mysql端口从3306更改为3307时,这种情况就发生了,但是在更改端口(3307->3306)之后,它又正常工作了。

相关问题