博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hibernate 中连接释放的策略
阅读量:5839 次
发布时间:2019-06-18

本文共 732 字,大约阅读时间需要 2 分钟。

hot3.png

hibernate 中连接释放的策略hibernate. connection. release_ mode有以下四种属性:

default     :    默认方式  
on_close    :    session关闭时释放连接
after_transcation :  事务处理结束后,以事务为单位进行连接的释放
after_statement  :  每次执行后释放当前连接。
四种释放连接的颗粒度,从粗到细:
  1、采用第一种default配置,在spring中配置事务管理,由于事务颗粒度比较小,事务执行结束,也不会触发释放的操作,
直至达连接设置回收的最大超时时间才能回收连接,连接会迟迟不释放,导致连接池被占满。
  2、采用第二种on_close, 同样在spring中配置事务,连接一直等到session 关闭时才会,释放较慢
,同样会导致连接池被沾满
  3、采用after_transcation 的策略释放链接,每次事务都会释放链接。采用xml配置进行全局事务管理的
配置,则不会出现连接池沾满的现象。但是如果采用注解,而某个持久层的 
Dao类未标注Transactional注解,或者xml配置中遗漏了某个dao的事务管理配置,则该Dao操作执行结束,
并不是一个事务的结束,不会释放链接,导致链接迟迟不能被释放,久而久之会导致连接池被占满。
  4、after_statement 的策略释放连接及时。但也有一个弊端,由于每一次执行都会释放连接,如果一个
事务需要几个执行操作,但第一次执行时连接就被释放,连接已归还给连接池了,第二次执行时获取新的连接,
这样就无法保证事务性了。
 

转载于:https://my.oschina.net/u/2277088/blog/3014323

你可能感兴趣的文章
Linux crontab定时执行任务
查看>>
mysql root密码重置
查看>>
33蛇形填数
查看>>
选择排序
查看>>
SQL Server 数据库的数据和日志空间信息
查看>>
前端基础之JavaScript
查看>>
自己动手做个智能小车(6)
查看>>
自己遇到的,曾未知道的知识点
查看>>
P1382 楼房 set用法小结
查看>>
分类器性能度量
查看>>
docker 基础
查看>>
写一个bat文件,删除文件名符合特定规则,且更改日期在某
查看>>
我的友情链接
查看>>
写Use Case的一种方式,从oracle的tutorial抄来的
查看>>
【C#】protected 变量类型
查看>>
Ubuntu解压
查看>>
爬虫_房多多(设置随机数反爬)
查看>>
藏地密码
查看>>
爬虫去重(只是讲了去重的策略,没有具体讲实现过程,反正就是云里雾里)...
查看>>
react中将px转化为rem或者vw
查看>>