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