我正在努力让我的数据库和我的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?");
}
}
23条答案
按热度按时间vpfxa7rd1#
如果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
. 请注意,对于所有服务器版本,默认设置sslMode
是PREFERRED
,它相当于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,必须显式启用。z4iuyo4d2#
当java出堆时,我发现了这个异常。如果我尝试在ram中放入许多数据项—首先我捕获“通信链路故障”,然后捕获“outofmemoryerror”。
我记录了它,我减少了内存消耗(删除1/2的数据),一切正常。
soat7uwm3#
当我在my.ini和php.ini文件中将mysql端口从3306更改为3307时,这种情况就发生了,但是在更改端口(3307->3306)之后,它又正常工作了。
mpgws1up4#
我可能在这里找错了树,但是你的异常似乎表明你的mysql服务器不可用。
线程“main”com.mysql.jdbc.exceptions.jdbc4.communicationsexception中出现异常:通信链路故障上次成功发送到服务器的数据包是0毫秒前的。驱动程序尚未从服务器接收到任何数据包。在。。。
如果你尝试(从终点站)会发生什么
系统将提示您输入与用户名关联的密码。在您给出正确的密码之后,mysql客户端是否连接?
如果没有,您可能必须从首选项启动mysql。您还可以将其设置为在启动时运行。
sigwle7e5#
从mysql下载mysql-jdbc-type-4-treiber(例如,从mysql-connector-java-5.1.11.zip下载mysql-connector-java-5.1.11-bin.jar)。
您需要在编译和运行时在类路径中包含驱动程序jar。
gopyfrb36#
我也有同样的问题,下面是如何解决的:
jsp正在调用servlet中尚未定义的属性。
我有两个列名,通过它们传递给一个对象
ResultSet (getString("columnName"))
与我数据库中的列名不匹配。我不确定哪一个解决了这个问题,但它起了作用。另外,请确保您创建了一个新的
Statement
以及ResultSet
对于每个表查询。ckocjqey7#
这个
com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
如果数据库连接长时间处于空闲状态,则会发生异常。此空闲连接在
connection.isClosed();
但如果我们尝试执行语句,那么它将引发此异常,所以我建议使用数据库池。6tdlim6h8#
我用一种简单的方法解决了这个问题,这对我很有用。我遇到了seme问题“com.mysql.jdbc.exceptions.jdbc4.communicationsexception:communications link failure”。在我的db.properties文件中,我有:url:jdbc:mysql://localhost:90/mydb,只删除了端口url,结果是这样的url:jdbc:mysql://localhost/mydb 这对我很有效。
ddrv8njm9#
请在/etc/mysql/my.cnf文件中更新您的ip地址
重新启动mysql deamon和mysql服务。
5lhxktic10#
刚刚经历过。
必须使其工作:(这可以放在静态块初始化)
通过以下方式获得连接:
而不是指定登录参数
当做。
pes8fvy911#
所以,你有一个
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示例安全吗?
6xfqseft12#
如果您正在使用
WAMP
或者XAMP
安装mysql数据库的服务器。然后您必须显式地启动mysql服务器,否则它将显示com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
连接数据库时bgtovc5b13#
远程调用mysql
将远程用户添加到mysql,例如ip=remoteip:
允许远程访问mysql(默认情况下不允许所有外部调用):
对于最新版本的jdbc驱动程序,jdbc:
iyfamqjs14#
如果mysql版本8或更高版本的用户更新了连接器
axzmvihb15#
可能是个简单的jar问题