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