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

转载 2016年06月01日 13:59:20

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

标签: 数据库连接池
 18615人阅读 评论(0) 收藏 举报
 分类:
 

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

相关文章推荐

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

java.sql.SQLException: Io 异常: Connection reset 当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行...

java 中的connection reset 异常处理分析

在Java中常看见的几个connection rest exception, Broken pipe, Connection reset,Connection reset by peer Socke...

JDBC Connection Reset问题分析

2014年7月13日 半年前开始,项目组测试MM在验证功能时,经常报怨讲测试环境上的应用在启动时很慢,偶尔会报失败,遇到类似问题多数情况下重新启动一次就可以启动成功,但少数时候也有反复启动不成功的案...

关于java.sql.SQLRecoverableException: Closed Connection异常的解决方案

在项目中碰到了一个应用异常,从表象来看应用僵死。查看Weblogic状态为Running,内存无溢出,但是出现多次线程堵塞。查看Weblogic日志,发现程序出现多次Time Out。 ...
  • gavinloo
  • gavinloo
  • 2013年09月30日 21:52
  • 27174

java.sql.SQLRecoverableException: IO 错误: Socket closed

今天weblogic的alllog日志报了很多socket closed的错误。 ### Cause: org.hibernate.exception.JDBCConnectionException:...

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

java.sql.SQLException: Io 异常: Connection reset当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操...

Connection reset by peer: socket write error错误分析及解决

Connection reset by peer: socket write error错误分析:常出现的Connection reset by peer: 原因可能是多方面的,不过更常见的原因是: ...
  • zangpuu
  • zangpuu
  • 2011年07月20日 09:47
  • 193655

connection reset errors 的解决办法

25.2.1. Oracle: Connection Reset Errors Problem: When using the default Sqoop connector for O...

java.sql.SQLRecoverableException: 关闭的连接 解决办法

程序如果长时间不进行数据库操作,那么数据源中的 Connection 很可能已经断开。其原因有可能是防火墙,或者连接的数据库设置的超时时间。 问题总结: 当数据库连接池中的连接被创建而长时间不使用...

java.sql.SQLRecoverableException: IO 错误: Broken pipe

java.sql.SQLRecoverableException: IO 错误: Broken pipe
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:解决Caused by: java.sql.SQLRecoverableException: IO Error: Connection reset相关问题
举报原因:
原因补充:

(最多只允许输入30个字)