视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle连接Ioexception:TheNetworkAdaptercouldnot
2020-11-09 10:04:36 责编:小采
文档

今天碰到,Tomcat 连 Oracle 数据库时出现如下异常信息,org.apache.commons.dbcp.SQLNestedException:Cannot create PoolableConnectionFactory(Io exception : The Network Adapter could not establish the connection)

今天碰到,Tomcat 连 Oracle 数据库时出现如下异常信息, org.apache.commons.dbcp.SQLNestedException:Cannot create PoolableConnectionFactory (Io exception : The Network Adapter could not establish the connection)

具体错误

java.sql.SQLRecoverableException: Io 异常: The Network Adapter could not establish the connection
at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:101)
at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:112)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:173)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:229)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:458)
at oracle.jdbc.driver.T4CConnection.logon(T4CConnection.java:411)
at oracle.jdbc.driver.PhysicalConnection.(PhysicalConnection.java:490)
at oracle.jdbc.driver.T4CConnection.(T4CConnection.java:202)
at oracle.jdbc.driver.T4CDriverExtension.getConnection(T4CDriverExtension.java:33)
at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:474)
at java.sql.DriverManager.getConnection(Unknown Source)
at java.sql.DriverManager.getConnection(Unknown Source)
at chap6.DBUtil.getConnection(DBUtil.java:14)
at chap6.StatementDemo.main(StatementDemo.java:15)
java.sql.SQLException: 驱动错误或连接失败!
at chap6.DBUtil.getConnection(DBUtil.java:20)
at chap6.StatementDemo.main(StatementDemo.java:15)

解决办法一

后来在防火墙开了3个端口, 8080, 8009, 8005, 问题搞定


解决办法二

oracle的thin连接分为两种,一个是SID,一个是SERVICE NAME,而这两个的差别就在于服务器如何是配置SID,还是SERVICE NAME,配置完数据库后,可以在

代码如下

D:oracleproduct10.2.0db_1NETWORKADMIN

目录下查找,tnsnames.ora 文件,看看里面的参数

根据上面的数据配置确认是哪个方式

A,如果是SID模式,JDBC连接数据库的形式是

代码如下

String url = "jdbc:oracle:thin:@//192.168.10.105:1522:uportal";

请注意在连数据实例的时候,是使用 英文冒号 :

B,如果是SERVICE 模式,JDBC连接数据的形式是

代码如下

String url = "jdbc:oracle:thin:@//192.168.10.105:1522/uportal";

请注意在连数据实例的时候,是使用 英文斜杠 /

下载本文
显示全文
专题