码迷,mamicode.com
首页 > 数据库 > 详细

C3P0 hibernate数据库连接释放策略

时间:2015-05-13 12:02:48      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:

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 的策略释放连接及时。 但也有一个弊端,由于每一次执行都会释放连接,如果一个事务需要几个执行操作,但第一次执行时连接就被释放,连接已归还给连接池了,第二次执行时获取新的连接,这样就无法保证事务性了。

C3P0 hibernate数据库连接释放策略

标签:

原文地址:http://www.cnblogs.com/nullexception/p/4499760.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!