DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
来源:互联网 发布:淘宝客佣金计算 编辑:程序博客网 时间:2024/05/24 05:54
解决方法:
spring中datasource的配置如下:
<bean id="dispatchdataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:myserver" />
<property name="username" value="user1" />
<property name="password" value="pwd" />
<property name="maxActive" value="10000" />
<property name="maxIdle" value="30" />
<property name="minIdle" value="2" />
<property name="maxWait" value="600000" />
<property name="testOnBorrow" value="true"/>
<property name="testWhileIdle" value="true"/>
<property name="validationQuery" value="select 1 from dual"/>
</bean>
分析:
DBCP使用apache的对象池ObjectPool作为连接池的实现,有以下主要的方法
Object borrowObject() throws Exception;从对象池取得一个有效对象
void returnObject(Object obj) throws Exception;使用完的对象放回对象池
void invalidateObject(Object obj) throws Exception;使对象失效
void addObject() throws Exception;生成一个新对象
ObjectPool的一个实现就是GenericObjectPool,这个类使用对象工厂PoolableObjectFactory实现对象的生成,失效检查等等功能,以其实现数据库连接工厂PoolableConnectionFactory做以说明,主要方法:
Object makeObject() throws Exception; 使用ConnectionFactory生成新连接
void destroyObject(Object obj) throws Exception;关闭连接
boolean validateObject(Object obj); 验证连接是否有效,如果_validationQuery不空,则使用该属性作为验证连接是否有效的sql语句,查询数据库
void activateObject(Object obj) throws Exception;激活连接对象
void passivateObject(Object obj) throws Exception; 关闭连接生成过的Statement和ResultSet,使连接处于非活动状态
而GenericObjectPool有几个主要属性
_timeBetweenEvictionRunsMillis:失效检查线程运行时间间隔,默认-1
_maxIdle:对象池中对象最大个数
_minIdle:对象池中对象最小个数
_maxActive:可以从对象池中取出的对象最大个数,为0则表示没有限制,默认为8
在构造GenericObjectPool时,会生成一个内嵌类Evictor,实现自Runnable接口。如果 _timeBetweenEvictionRunsMillis大于0,每过_timeBetweenEvictionRunsMillis毫秒 Evictor会调用evict()方法,检查对象的闲置时间是否大于 _minEvictableIdleTimeMillis毫秒(_minEvictableIdleTimeMillis小于等于0时则忽略,默认为30 分钟),是则销毁此对象,否则就激活并校验对象,然后调用ensureMinIdle方法检查确保池中对象个数不小于_minIdle。在调用 returnObject方法把对象放回对象池,首先检查该对象是否有效,然后调用PoolableObjectFactory 的passivateObject方法使对象处于非活动状态。再检查对象池中对象个数是否小于_maxIdle,是则可以把此对象放回对象池,否则销毁此对象。
还有几个很重要的属性,_testOnBorrow、_testOnReturn、_testWhileIdle,这些属性的意义是取得、返回对象和空闲时是否进行验证,检查对象是否有效,默认都为false即不验证。所以当使用DBCP时,数据库连接因为某种原因断掉后,再从连接池中取得连接又不进行验证,这时取得的连接实际已经时无效的数据库连接了。网上很多说 DBCP的bug应该都是如此吧,只有把这些属性设为true,再提供_validationQuery语句就可以保证数据库连接始终有效了,oracle数据库可以使用SELECT COUNT(*) FROM DUAL,不过DBCP要求_validationQuery语句查询的记录集必须不为空,可能这也可以算一个小小的BUG,其实只要_validationQuery语句执行通过就可以了。
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException: Io 异常: Connection reset
- java.sql.SQLException:IO异常:Connection reset...........
- tomcat的Connection reset异常
- 从Connection Reset问题浅谈DBCP的使用技巧
- HBase异常:java.io.IOException: Connection reset by peer
- 关于WEBSERVICE的Connection reset异常
- DBCP代码研读以及就数据库连接失效的解决
- DBCP代码研读以及就数据库连接失效的解决
- oracle创建视图报ora-01031
- Google三大技术的论文之 MapReduce 中译版
- HTML 5新特性及其技巧
- shell简明教程
- Google 三在技术论文 之 GFS 中译版
- DBCP数据库连接失效的解决方法(Io 异常:Connection reset)
- MFC 注册表操作
- android4.0打电话,来电过程
- 详解:数据库名、实例名、ORACLE_SID、数据库域名、全局数据库名、服务名
- 读取文件行
- Android SmackAPI使用中遇到的问题
- MFC获取系统时间
- .NET与JAVA,谁是未来?
- Can't connect to MySQL server on IP(10060)