Hibernate+EHCache配置二级缓存
来源:互联网 发布:查看守望先锋数据 编辑:程序博客网 时间:2024/05/16 15:59
1.前言
Hibernate中的二级缓存,二级缓存是属于SessionFactory级别的缓存机制。第一级别的缓存是Session级别的缓存,是属于事务范围的缓存,由Hibernate管理,一般无需进行干预。第二级别的缓存是SessionFactory级别的缓存,是属于进程范围的缓存。
2.Hibernate二级缓存
1.分类
二级缓存也分为了两种
内置缓存:Hibernate自带的,不可卸载,通常在Hibernate的初始化阶段,Hibernate会把映射元数据和预定义的SQL语句放置到SessionFactory的缓存中。该内置缓存是只读的。
外置缓存:通常说的二级缓存也就是外置缓存,在默认情况下SessionFactory不会启用这个缓存插件,外置缓存中的数据是数据库数据的复制,外置缓存的物理介质可以是内存或者硬盘。
hibernate二级缓存的结构
2.并发访问策略
transactional
(事务型)
仅在受管理的环境中适用
提供Repeatable Read事务隔离级别
适用经常被读,很少修改的数据
可以防止脏读和不可重复读的并发问题
缓存支持事务,发生异常的时候,缓存也能够回滚
read-write
(读写型)
提供Read Committed事务隔离级别
在非集群的环境中适用
适用经常被读,很少修改的数据
可以防止脏读
更新缓存的时候会锁定缓存中的数据
nonstrict-read-write
(非严格读写型)
适用极少被修改,偶尔允许脏读的数据(两个事务同时修改数据的情况很少见)
不保证缓存和数据库中数据的一致性
为缓存数据设置很短的过期时间,从而尽量避免脏读
不锁定缓存中的数据
read-only
(只读型)
适用从来不会被修改的数据(如参考数据)
在此模式下,如果对数据进行更新操作,会有异常
事务隔离级别低,并发性能高
在集群环境中也能完美运作
3.二级缓存的配置
1.hibernate支持的缓存插件
•EHCache: 可作为进程范围内的缓存,存放数据的物理介质可以是内存或硬盘,对Hibernate的查询缓存提供了支持•OpenSymphony`:可作为进程范围内的缓存,存放数据的物理介质可以是内存或硬盘,提供了丰富的缓存数据过期策略,对Hibernate的查询缓存提供了支持•SwarmCache:可作为集群范围内的缓存,但不支持Hibernate的查询缓存•JBossCache:可作为集群范围内的缓存,支持Hibernate的查询缓存四种缓存插件支持的并发范围策略如下图
2.二级缓存配置
下面以ehcache缓存为例,来讲一下二级缓存的配置
2.1 拷贝jar包
如要第三方的jar包ehcache-1.5.0.jar,并且依赖于
依赖backport-util-concurrent 和 commons-logging
2.2 在hibernate.cfg.xml中开启二级缓存
<propertyname="hibernate.cache.use_second_level_cache">true</property>
2.3 配置二级缓存技术提供商
<propertyname="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
2.4 配置缓存数据对象并发策略
方式一 在hbm文件中配置
方式二 在cfg文件配置(集中配置)
方式三 在实体类上,使用hibernatede的@Cache注解
@Entity@Table(name = "S_CONFIG")@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) //缓存策略:NONSTRICT_READ_WRITE:只偶尔需要更新数据,不需要严格的事物隔离public class SConfig {2.5 添加二级缓存配置文件
在src中配置ehcache.xml,将ehcache.jar包中的ehcache-failsafe.xml 改名 ehcache.xml 放入 src
cache参数详解:
● name:指定区域名
● maxElementsInMemory :缓存在内存中的最大数目
● maxElementsOnDisk:缓存在磁盘上的最大数目
● eternal :设置是否永远不过期
● overflowToDisk : 硬盘溢出数目
● timeToIdleSeconds :对象处于空闲状态的最多秒数后销毁
● timeToLiveSeconds :对象处于缓存状态的最多秒数后销毁
● memoryStoreEvictionPolicy:缓存算法,有LRU(默认)、LFU、LFU
关于缓存算法,常见有三种:
● LRU:(Least Rencently Used)新来的对象替换掉使用时间算最近很少使用的对象
● LFU:(Least Frequently Used)替换掉按命中率高低算比较低的对象● LFU:(First In First Out)把最早进入二级缓存的对象替换掉
扩展: timeToIdleSeconds vs timeToLiveSeconds
If you set both, the
expirationTime
will beMath.min(ttlExpiry, ttiExpiry)
, wherettlExpiry = creationTime + timeToLive //创建时间 + 存活时间ttiExpiry = mostRecentTime + timeToIdle //最近一次访问时间 + 空闲时间
4.Demo测试二级缓存
控制台输出:
查询了两次,只打印了一次sql,说明二级缓存起了作用。
转载地址:http://blog.csdn.net/luckyzhoustar/article/details/47748179
- Hibernate+ehcache二级缓存配置
- Hibernate ehcache配置二级缓存
- Hibernate配置Ehcache二级缓存
- EhCache配置Hibernate二级缓存
- Hibernate+EhCache配置二级缓存
- Hibernate ehcache配置二级缓存
- Hibernate+EhCache配置二级缓存
- Hibernate+EHCache配置二级缓存
- hibernate二级缓存 Ehcache配置详解
- hibernate二级缓存 Ehcache配置详解
- Hibernate EhCache 二级缓存配置.pdf
- Hibernate 使用ehcache配置二级缓存
- Spring+Hibernate下配置Hibernate二级缓存EhCache
- Hibernate之Hibernate+EHCache配置二级缓存实战
- Spring+Hibernate下配置Hibernate二级缓存EhCache
- Hibernate中ehcache二级缓存配置方法
- Hibernate ehcache配置二级缓存及说明
- Hibernate JPA 中配置Ehcache二级缓存
- poi导出word
- bzoj 3944 Sum 杜教筛
- css设置小图标
- Linux的帧缓冲(Frame Buffer)之一:原理及控制参数
- HDU 4035 maze 概率期望dp
- Hibernate+EHCache配置二级缓存
- selenium+Chromedriver.exe的位置的设置
- HDU 5930GCD
- 物联网应用繁花似锦,LoRa和NB-IoT如何PK?
- BigDecimal 类型
- Cannot convert value '0000-00-00 00:00:00' from column 22 to TIMESTAMP
- MongoDB 关于MongoDB Shell的使用 (三)
- Apache 转发代理 IIS , 共用80端口
- Python知识点总结梳理