现在的位置: 首页 > 综合 > 正文

Hibernate Cannot release connection

2013年11月27日 ⁄ 综合 ⁄ 共 1059字 ⁄ 字号 评论关闭

问题:

    系统采用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. 故加上这两个参数后,这个异常就不会再出现了。

抱歉!评论已关闭.