The Network Adapter could not establish the connection

本文详细阐述了在使用Oracle数据库时遇到的连接错误问题及解决方法,包括检查IP配置、防火墙设置、数据库监听状态以及确认JDBC版本与Java环境的一致性。最终通过更换驱动包ojdbc6.jar成功解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   这两天做了一个程序,总是会报错误日志:

    错误信息如下:

java.sql.SQLException: Io 异常: The Network Adapter could not establish the connection
        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:439)
        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:154)
        at org.logicalcobwebs.proxool.DefaultConnectionBuilder.buildConnection(DefaultConnectionBuilder.java:39)
        at org.logicalcobwebs.proxool.Prototyper.buildConnection(Prototyper.java:159)
        at org.logicalcobwebs.proxool.Prototyper.sweep(Prototyper.java:102)
        at org.logicalcobwebs.proxool.PrototyperThread.run(PrototyperThread.java:44)

 

    但是并不影响操作数据库,插入、更新等操作一样可以执行,也没有在意。

    今天领导问起来,因为系统会自动检查错误日志,会发邮件给大家。因此,必须要解决了。

    在网上搜了一下一般的解决办法如下:

    这种异常的出现大致上有下面几种:


1。IP错误。
在设置URL时错误,例如:jdbc:oracle:thin:@192.168.248.154:1521:test

数据库服务器不正确:ping 服务器IP是否正确。不正确,将URL更改为正确
端口号错误:一般不会错误。

2。防火墙
如果机器上安装有放火墙,可能是服务器端口号屏蔽而造成的。关闭防火墙后,尝试重新连接。


3。数据库监听未启动

启动Oracle的监听服务

 

 

4.如果DB是unix/linux系统上,则把 /etc/hosts中的IP记录到客户端(此方法为DBA提供)

  在我这问题上没有起到作用。

 

5.如果通过pl/sql查询的话,

   tnsnames.ora中是否添加了相应的内容。

 

最后一点是我本次解决的办法,记得之前有同学分享了JDBC版本的问题,我查看了连接的服务器上数据库

版本为oracle 10.2。我执行程序的驱动包为ojdbc14.jar,该驱动包为随oracle10.2发布的驱动包,

按理说 不应该有问题的。后来我看到其中有说ojdbc14.jar支持jdk1.4和jdk1.5。因此我去查看了

java jdk安装目录,/usr/java,是jdk1.6.0_21版本的。随ORCALE 11G发布的jdbc驱动包为ojdbc6.jar,

支持jdk1.6,高版本的驱动包应该具有兼容性吧。于是删掉原来的ojdbc14.jar,换成ojdbc6.jar。重跑程序,

没有error日志。问题解决。

参考网址http://apps.hi.baidu.com/share/detail/47434067

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值