解决Caused by: java.sql.SQLRecoverableException: IO Error: Connection reset相关问题

java.sql.SQLException: Io 异常: Connection reset

当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操作时仍然使用的是无效的数据库连接,这样,就导致客户端程序报“ java.sql.SQLException: Io 异常: Connection reset” 或“java.sql.SQLException 关闭的连接”异常。

在配置数据源后面加上

<property name="validationQuery" value="select * from dual"/>


配置后,客户端在使用一个无效的连接时会先对该连接进行测试,如果发现该连接已经无效,则重新从连接池获取有效数据库连接来使用。

 

在tomcat的context.xml里面设置数据源时候可参考:

 <Resource auth="Container"
  driverClassName="oracle.jdbc.OracleDriver"
  type="javax.sql.DataSource" 
  url="jdbc:oracle:thin:@11.11.11.45:1521:orcl"
  name="jdbc/login"
  username="login"
  password="login"
  maxActive="15"
  maxIdle="10"
  maxWait="-1"
  minIdle="2"
  removeAbandonedTimeout="5"
  testOnBorrow="true"
  testWhileIdle="true"
  testOnReturn="true"
  removeAbandoned="true"
  logAbandoned="true"
  validationQuery="select 1 from dual"
 /> 
 
 <Resource auth="Container"
  driverClassName="oracle.jdbc.OracleDriver"
  type="javax.sql.DataSource" 
  url="jdbc:oracle:thin:@11.11.11.44:1521:orcl"
  name="jdbc/intraweb"
  username="intraweb"
  password="intraweb"
  maxActive="15"
  maxIdle="10"
  maxWait="-1"
  minIdle="2"
  removeAbandonedTimeout="5"
  testOnBorrow="true"
  testWhileIdle="true"
  testOnReturn="true"
  removeAbandoned="true"
  logAbandoned="true"
  validationQuery="select 1 from dual"
 />


-------------------------------------------------------------

以上是从网上搜到一篇文章。网上跟这个问题相关的解决思路是Connection Reset的原因有可能有以下几种原因:

1.配置的数据连接池的连接数不够用;

2.数据库的连接池中的连接,长时间不用,数据库主动断开连接,而客户端不知道,在用的时候仍然拿到的是无效的连接;

分别对应以上的两种猜想的原因,进行处理:

1.配置连接池的最大、最小、空闲连接数等;

2.配置对连接池里的连接进行有效性检查,如,配置有效性连接检查sql语句,配置是否进行有效性检查等;


以上只是思路,具体配置内容要根据不同的数据源进行不同的配置,解决思路可以参照上面。至于是否还有别的方面原因,暂时未知。

我的项目中用到的是c3p0数据源,当时就按c3p0的配置方式添加了有效性检查的相关配置,关于c3p0的详细配置可以参照:

http://blog.csdn.net/majian_1987/article/details/18598857

  • 10
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误通常是由于数据库连接失败引起的。可能的原因包括网络问题、数据库服务器未启动、数据库服务器名称或端口号不正确等。以下是一些可能的解决方案: 1.检查数据库服务器是否已启动,并确保您使用的是正确的主机名和端口号。 2.检查网络连接是否正常。您可以尝试使用ping命令测试与数据库服务器的连接。 3.检查防火墙设置,确保允许从您的应用程序服务器连接到数据库服务器。 4.检查您的应用程序代码,确保您正在使用正确的JDBC URL和驱动程序类名。 5.尝试使用telnet命令测试与数据库服务器的连接。如果连接失败,则可能需要联系您的网络管理员。 6.如果您使用的是连接池,请确保您已正确配置连接池参数,例如最大连接数和最大等待时间。 以下是一个Java代码示例,用于连接Oracle数据库并执行查询: ```java import java.sql.*; public class OracleJDBCExample { public static void main(String[] args) { try { // 加载Oracle JDBC驱动程序 Class.forName("oracle.jdbc.driver.OracleDriver"); // 建立数据库连接 Connection conn = DriverManager.getConnection( "jdbc:oracle:thin:@localhost:1521:orcl", "username", "password"); // 创建Statement对象 Statement stmt = conn.createStatement(); // 执行查询 ResultSet rs = stmt.executeQuery("SELECT * FROM employees"); // 处理结果集 while (rs.next()) { System.out.println(rs.getString("first_name") + " " + rs.getString("last_name")); } // 关闭连接 rs.close(); stmt.close(); conn.close(); } catch (Exception e) { System.out.println("Error: " + e.getMessage()); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值