日期:2014-05-20  浏览次数:20609 次

jdbc无法连接数据库,相当诡异
环境:
数据库服务器与java程序不在同一个子网。
现状:
1.sqlplus可以连接
2.java程序无法连接
报错如下:
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:255)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:387)
at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:414)
at oracle.jdbc.driver.T4CConnection.<init>(T4CConnection.java:165)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:35)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:801)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
3.抓包发现,数据包超时重传,重传失败后报2中的异常信息
4.oracle数据库所在机器防火墙未开启
5.不是网上所说连接池的问题,该应用未使用数据库连接池
6.jdbc驱动正常

请高手进来指导。

------解决方案--------------------
再不同的网段的机器上可以通过sqlplus连接吗
如果可以检查一下tns里的ip,port和servicename和你程序中使用的相同吗


------解决方案--------------------
引用:
引用:
再不同的网段的机器上可以通过sqlplus连接吗
如果可以检查一下tns里的ip,port和servicename和你程序中使用的相同吗

可以sqlplus连接,tns配置的ip,port servicename都一样。
tnsping ip 是ok的

不可能没有问题,再仔细检查一下,出问题必然就有错的地方,你在这里问,还不如多去检查两遍