dbcp连接

 

Hibernate Cannot release connection

分类: Hibernate   120人阅读  评论(0)  收藏  举报

问题: 
    系统采用Spring MVC 2.5 + Spring 2.5 + Hibernate 3.2架构,其中数据源连接池采用的是Apache commons DBCP。问题是这样的,系统运行一段时间后(大致每隔8小时),访问系统会出现如下错误,再次访问恢复正常。


解决: 
    造成Cannot release connection的原因有很多,要具体问题具体分析。从异常分析,造成这个异常org.hibernate.exception.GenericJDBCException: Cannot release connection 归根结底是 Caused by: java.sql.SQLException: Already closed.  即连接已关闭。所以解决的办法就要从DBCP的参数配置入手,见下面的参数配置properties文件。 #### :: Apache DBCP :: ####
 jdbc.driverClassName
 =  oracle.jdbc.driver.OracleDriver
 jdbc.url
 = jdbc:oracle:thin:@ 10.165 . 153.9 : 1521  :PRDC
 jdbc.username =  guser
 jdbc.password
 =guser 
 #初始化连接
 jdbc.initialSize 
= 0 
 #连接池的最大活动个数
 jdbc.maxActive 
= 20 
 #没有人用连接的时候,最大闲置的连接个数。
 jdbc.maxIdle 
= 100 
 #没有人用连接的时候,最小闲置的连接个数。
 jdbc.minIdle 
= 0 
 #超时等待时间以毫秒为单位
 jdbc.maxWait 
= 10000 
 #是否自动回收超时连接
 jdbc.removeAbandoned 
= true 
 #设置被遗弃的连接的超时的时间(以秒数为单位),即当一个连接被遗弃的时间超过设置的时间,则它会自动转换成可利用的连接。默认的超时时间是300秒。
 jdbc.removeAbandonedTimeout 
= 60 
 #是否在自动回收超时连接的时候打印连接的超时错误
 jdbc.logAbandoned  
=   true 
 #给出一条简单的sql语句进行验证
 jdbc.validationQuery=select 1 from dual
 #在取出连接时进行有效验证
 jdbc.testOnBorrow=true
其中标红的两个参数的作用是对池化连接进行验证,This will ensure that DBCP only hands out good connections to Hibernate. 故加上这两个参数后,这个异常就不会再出现了。

http://blog.csdn.net/zyj8170/article/details/5948219
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值