Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/343.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 在windows中连接到db2服务器_Java_Jdbc_Db2_Database Server - Fatal编程技术网

Java 在windows中连接到db2服务器

Java 在windows中连接到db2服务器,java,jdbc,db2,database-server,Java,Jdbc,Db2,Database Server,我使用这段java代码连接到db2数据库服务器 import java.sql.*; import java.util.logging.Level; import java.util.logging.Logger; public class DatabaseConnect { Connection co=null; Statement st=null; PreparedStatement pstmt; ResultSet rs;

我使用这段java代码连接到db2数据库服务器

import java.sql.*;
import java.util.logging.Level;
import java.util.logging.Logger;

public class DatabaseConnect {

    Connection co=null;
        Statement st=null;
        PreparedStatement pstmt;
        ResultSet rs;

        int status;

        void makeConnection() throws ClassNotFoundException, SQLException
        {
            Class.forName("com.ibm.db2.jcc.DB2Driver");
            co=DriverManager.getConnection("jdbc:db2://localhost:50000/databasename","username","password");
            //st=co.createStatement();
        }
        Connection getConnection()
        {
            return co;
        }
        void endConnection() throws SQLException
        {
            co.close();
        }

        public static void main(String args[]) throws ClassNotFoundException, SQLException
        {
            DatabaseConnect db=new DatabaseConnect();
            db.makeConnection();

            new MaintainHash().createHashMap(db.getConnection());

            new Login(db.getConnection()).setVisible(true);

        }

}
如果主机名是localhost,则效果很好,但当我提供远程服务器的主机名时,程序挂起并显示此错误

    Exception in thread "main" com.ibm.db2.jcc.am.DisconnectNonTransientConnectionException: [jcc][t4][2043][11550][3.68.61] Exception java.net.ConnectException: Error opening socket to server /192.168.80.1 on port 50,000 with message: Connection timed out: connect. ERRORCODE=-4499, SQLSTATE=08001
    at com.ibm.db2.jcc.am.gd.a(gd.java:329)
    at com.ibm.db2.jcc.am.gd.a(gd.java:410)
    at com.ibm.db2.jcc.t4.ac.a(ac.java:439)
    at com.ibm.db2.jcc.t4.ac.<init>(ac.java:96)
    at com.ibm.db2.jcc.t4.a.b(a.java:358)
    at com.ibm.db2.jcc.t4.b.newAgent_(b.java:2066)
    at com.ibm.db2.jcc.am.Connection.initConnection(Connection.java:780)
    at com.ibm.db2.jcc.am.Connection.<init>(Connection.java:725)
    at com.ibm.db2.jcc.t4.b.<init>(b.java:333)
    at com.ibm.db2.jcc.DB2SimpleDataSource.getConnection(DB2SimpleDataSource.java:233)
    at com.ibm.db2.jcc.DB2SimpleDataSource.getConnection(DB2SimpleDataSource.java:199)
    at com.ibm.db2.jcc.DB2Driver.connect(DB2Driver.java:474)
    at com.ibm.db2.jcc.DB2Driver.connect(DB2Driver.java:115)
    at java.sql.DriverManager.getConnection(DriverManager.java:664)
    at java.sql.DriverManager.getConnection(DriverManager.java:247)
    at DatabaseConnect.makeConnection(DatabaseConnect.java:31)
    at DatabaseConnect.main(DatabaseConnect.java:58)
Caused by: java.net.ConnectException: Connection timed out: connect
    at java.net.DualStackPlainSocketImpl.connect0(Native Method)
    at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:345)
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
    at java.net.Socket.connect(Socket.java:589)
    at com.ibm.db2.jcc.t4.w.run(w.java:49)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.ibm.db2.jcc.t4.ac.a(ac.java:425)
    ... 14 more
Java Result: 1
BUILD SUCCESSFUL (total time: 25 seconds)
线程“main”com.ibm.db2.jcc.am.disconnectNontTransientConnectionException:[jcc][t4][2043][11550][3.68.61]异常java.net.ConnectException:在端口50000上打开服务器/192.168.80.1的套接字时出错,消息为:连接超时:连接。ERRORCODE=-4499,SQLSTATE=08001
com.ibm.db2.jcc.am.gd.a(gd.java:329)
位于com.ibm.db2.jcc.am.gd.a(gd.java:410)
com.ibm.db2.jcc.t4.ac.a(ac.java:439)
com.ibm.db2.jcc.t4.ac.(ac.java:96)
com.ibm.db2.jcc.t4.a.b(a.java:358)
在com.ibm.db2.jcc.t4.b.newAgent(b.java:2066)
位于com.ibm.db2.jcc.am.Connection.initConnection(Connection.java:780)
com.ibm.db2.jcc.am.Connection.(Connection.java:725)
com.ibm.db2.jcc.t4.b.(b.java:333)
位于com.ibm.db2.jcc.DB2SimpleDataSource.getConnection(DB2SimpleDataSource.java:233)
位于com.ibm.db2.jcc.DB2SimpleDataSource.getConnection(DB2SimpleDataSource.java:199)
位于com.ibm.db2.jcc.DB2Driver.connect(DB2Driver.java:474)
com.ibm.db2.jcc.DB2Driver.connect(DB2Driver.java:115)
位于java.sql.DriverManager.getConnection(DriverManager.java:664)
位于java.sql.DriverManager.getConnection(DriverManager.java:247)
在DatabaseConnect.makeConnection(DatabaseConnect.java:31)
位于DatabaseConnect.main(DatabaseConnect.java:58)
原因:java.net.ConnectException:连接超时:连接
位于java.net.DualStackPlainSocketImpl.connect0(本机方法)
位于java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)
位于java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:345)
位于java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
位于java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
位于java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)
位于java.net.socksocketimpl.connect(socksocketimpl.java:392)
位于java.net.Socket.connect(Socket.java:589)
com.ibm.db2.jcc.t4.w.run(w.java:49)
位于java.security.AccessController.doPrivileged(本机方法)
位于com.ibm.db2.jcc.t4.ac.a(ac.java:425)
... 14多
Java结果:1
生成成功(总时间:25秒)
我可以远程登录并ping到主机ip地址。

明白了。 这个解决方案实际上非常简单,而且有点离题。谢谢伊恩指出这一点。我必须将db2的端口号添加到防火墙的入站和出站规则中。 如果任何人有相同的问题,您可以按照以下步骤操作:

  • 转到控制面板中的Windows防火墙
  • 点击高级设置
  • 选择入站规则,然后单击新建规则
  • 选择端口选项,然后键入要添加的端口号
  • 对出站规则重复上述步骤

您是在询问如何连接到DB2服务器,还是如何编写Java代码?因为JDBC连接不关心数据库服务器是本地的还是远程的。也许看看数据库服务器上的防火墙吧?如果你不能从机器外部telnet到端口50000,那就是你的问题。修复防火墙规则。删除我的评论,因为它们具有误导性。