DBCP 学习-Abandoned

DBCP-330 DBCP-352

return new DelegatingDatabaseMetaData(this, _conn.getMetaData());
每次都会新建一个DelegatingDatabaseMetaData,而DelegatingDatabaseMetaData 自己添加到
connection trace中 addTrace,这样就会导致每次getMetaData()都会有一个DelegatingDatabaseMetaData
添加到这个connection中,从而GC不会回收.

解决方法:
在构建DelegatingDatabaseMetaData时调用super()而非super(c),这样就不会将这个新建的
DelegatingDatabaseMetaData添加到conn trace中。


DBCP-343
在执行长时间的任务时,由于AbandonedConfing中设置了removeAbandonedTimeout,在长时间没有响应之后
AbandonedObjectPool中removeAbandoned方法 会计算当前时间和getLastUsed的时间间隔,大于removeAbandonedTimeout
的话就会将连接remove。

解决方法:
在Statement PrepareStatement 中每次执行sql时,都设置一下lastUsed

如果执行一个语句,如查询某个表时间很长,那么DBCP还是会认为这个连接是abandoned的,
这时需要将removeAbandonedTimeout这个值设的大一些,或者设置 removeAbandoned为false,表示不删除过期的连接
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值