java - 无法连接到服务器上的远程数据库

标签 java mysql eclipse jdbc

我正在尝试使用 Eclipse 通过 MYSQL JDBC 连接器更新托管在服务器上的数据库表。

Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://49.**.***.115:3306/databasename";
String name = "user";
String password = "passs";

但是我无法从我的本地机器连接到数据库。我检查了上面提供的所有信息都是正确的。

可以请一些人告诉我下一步该做什么吗?

这里是错误:

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(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1121)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:357)
    at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2479)
    at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2516)
    at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2301)
    at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:834)
    at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
    at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:416)
    at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:346)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at connecttoDB.getconnection(connecttoDB.java:27)
    at updateDB.main(updateDB.java:17)
Caused by: java.net.ConnectException: Connection refused: connect
    at java.net.DualStackPlainSocketImpl.connect0(Native Method)
    at java.net.DualStackPlainSocketImpl.socketConnect(Unknown Source)
    at java.net.AbstractPlainSocketImpl.doConnect(Unknown Source)
    at java.net.AbstractPlainSocketImpl.connectToAddress(Unknown Source)
    at java.net.AbstractPlainSocketImpl.connect(Unknown Source)
    at java.net.PlainSocketImpl.connect(Unknown Source)
    at java.net.SocksSocketImpl.connect(Unknown Source)
    at java.net.Socket.connect(Unknown Source)
    at java.net.Socket.connect(Unknown Source)
    at java.net.Socket.<init>(Unknown Source)
    at java.net.Socket.<init>(Unknown Source)
    at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:259)
    at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:307)
    ... 16 more

最佳答案

您是否已确认可以从运行此代码的计算机连接到数据库服务器?看起来网络有问题。作为诊断 MySQL 连接问题的第一步,一个好主意是始终尝试从命令行连接以排除网络或凭据问题

mysql -uuser -p -h49.**.***.115 databasename

其中“user”是用户名,“databasename”是数据库,“49.**.***.115”是数据库服务器的ip。

关于java - 无法连接到服务器上的远程数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17777580/

相关文章:

java - Parse 中的 objectId 始终为 NULL

java - hibernate 5 java.lang.NoSuchMethodError org.jboss.logging.Logger.debugf

java - 您知道任何 Eclipse 插件可以帮助查找项目对 Maven 存储库的依赖关系吗?

java - web.xml 中的属性不起作用 eclipse kepler

java - 使用双链表进行堆栈

java - 在 Spring Security 中与 hasPermission 一起使用时,权限参数是否区分大小写?

MySQL GROUP BY查询问题

MySQL MYISAM 两个进程的并发问题

mysql - 无法扫描 sql 中订单日期的正确值

java - 如何修改 Eclipse 代码格式?