C3P0 hibernate数据库连接释放策略
2013-04-09 16:41
204 查看
hibernate 中连接释放的策略hibernate.connection.release_mode有一下四种属性: default : 默认方式 on_close : session关闭时释放连接。 after_transcation : 事务处理结束后,以事务为单位进行连接的释放 after_statement : 每次执行后就释放当前连接。 四种释放连接的颗粒度,从粗到细:
采用第一种default配置,在spring中配置事务管理,由于事务颗粒度比较小,事务执行结束,也不会触发释放的操作,直至达到连接设置回收的最大超时时间才能回收连接,连接会迟迟不释放,导致连接池被占满。
采用第二种on_close, 同样在spring中配置事务,连接一直等到session 关闭时才会被释放,释放较慢,同样会导致连接池被沾满
采用after_transcation 的策略释放链接,每次事务都会释放链接。采用xml配置进行全局事务管理的配置,则不会出现连接池沾满的现象。但是如果采用注解,而某个持久层的 Dao类未标注Transactional注解,或者xml配置中遗漏了某个dao的事务管理配置,则该Dao操作执行结束,并不是一个事务的结束,不会 释放链接,导致链接迟迟不能被释放,久而久之会导致连接池被占满。
after_statement 的策略释放连接及时。 但也有一个弊端,由于每一次执行都会释放连接,如果一个事务需要几个执行操作,但第一次执行时连接就被释放,连接已归还给连接池了,第二次执行时获取新的连接,这样就无法保证事务性了。
参考文档: http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/session-configuration.html 上文转自:http://gubaojian.blog.163.com/blog/static/166179908201212223824104/
相关文章推荐
- C3P0 hibernate数据库连接释放策略
- hibernate c3p0 连接无法释放 阻塞数据库操作
- 关于hibernate 利用c3p0连接mysql 数据库
- hibernate 利用c3p0连接mysql 数据库 can't open session
- 使用hibernate数据库连接不释放的问题
- spring + hibernate + c3p0 数据库连接用完问题排查
- hibernate 连接释放策略
- 关于Hibernate数据库连接进程释放
- 关于hibernate 利用c3p0连接mysql 数据库
- Hibernate、SpringJDBC中在注解模式下获取数据库连接
- 【python+mysql】数据库的连接与释放
- c3p0和dbcp进行配置数据库连接池上的区别
- Hibernate的连接数据库的方法
- hibernate结合spring框架配置连接数据库以及事务控制
- 数据库连接的两种实现方式(读取配置文件)——DBCP&C3P0;DBCP实现连接代码,C3P0实现连接代码——包含完整代码
- hibernate链接数据库链接池c3p0配置
- Hibernate 不同数据库的连接及SQL方言
- 数据库连接配置3 -- C3P0数据源
- 如何利用连接池C3P0连接数据库
- JAVA通过C3P0连接数据库