gemfire mysql_用GemFire做Hibernate二级缓存
com.gemstone.gemfire.modules.hibernate.GemFireRegionFactory
打开查询缓存
true
为查询缓存设置Cache Factory
com.gemstone.gemfire.modules.hibernate.GemFireQueryCacheFactory
共享缓存模式
ENABLE_SELECTIVE|DISABLE_SELECTIVE|ALL|NONE
ENABLE_SELECTIVE (默认值及推荐值): 仅标注为可缓存的实体会被缓存。
DISABLE_SELECTIVE: 仅标注为不可缓存的实体才不会被缓存。
ALL: 即使实体标为不可缓存也会被缓存。
NONE: 即使实体标为可缓存也不会被缓存。该选项意味着完全禁止二级缓存。
GemFire相关配置
设置GemFire缓存属性
PROPERTY_VALUE
设置GemFire缓存默认region类型
REGION_ATTRIBUTE
REGION_ATTRIBUTE是预定义region类型快捷定义中的任一个。默认为REPLICATE_HEAP_LRU。其他有效region快捷定义包括:
REPLICATE、 REPLICATE_PERSISTENT、 PARTITION、 PARTITION_PERSISTENT、
PARTITION_REDUNDANT、 PARTITION_REDUNDANT_PERSISTENT。
设置特定GemFire缓存region属性
REGION_ATTRIBUTE
缓存映射
@Cache
(
CacheConcurrencyStrategyusage();
String region() default "";
String include() default "all";
)
usage: 缓存并发策略(NONE, READ_ONLY, NONSTRICT_READ_WRITE, READ_WRITE,
TRANSACTIONAL)
region (可选项,默认为实体类的全类名或集合的全类名加属性名):
缓存region名
include (选项项,默认为all): all则缓存所有实体属性,non-lazy仅缓存非懒惰加载的实体属性。
对缓存实体试用注释
@Entity
@Cacheable
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class Forest { ... }
对缓存集合使用注释
@OneToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER)
@JoinColumn(name="CUST_ID")
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public SortedSet getTickets() {
return tickets;
}
GemFire支持READ_ONLY、NONSTRICT_READ_WRITE、READ_WRITE和TRANSACTIONAL缓存并发策略。
缓存模式
CacheMode 参数用于控制具体的 Session 如何与二级缓存进行交互。
CacheMode.NORMAL(默认值):从二级缓存中读写数据。
CacheMode.GET:从二级缓存中读取数据,但不会向二级缓存写数据。
CacheMode.PUT:仅向二级缓存写数据,但不从二级缓存中读数据。
CacheMode.REFRESH:仅向二级缓存写数据,但不从二级缓存中读数据。通过
hibernate.cache.use_minimal_puts 的设置,强制二级缓存从数据库中读取数据,刷新缓存内容。
void Session.setCacheMode(CacheMode cacheMode): 设置会话的缓存模式
Query Query.setCacheMode(CacheMode cacheMode):
为本次查询覆盖当前会话缓存模式
Criteria Criteria.setCacheMode(CacheMode cacheMode):
为本次查询覆盖当前会话缓存模式
gemfire mysql_用GemFire做Hibernate二级缓存相关推荐
- HibernateEHCache –Hibernate二级缓存
Welcome to the Hibernate Second Level Cache Example Tutorial. Today we will look into Hibernate EHCa ...
- hibernate二级缓存(三) 自定义实现一个简单的hibernate二级缓存
hibernate二级缓存(三) 自定义实现一个简单的hibernate二级缓存 前面我们已经提及过hibernate内部为二级缓存的扩展做了很多的实现.我们只需要实现RegionFactoryTem ...
- ssh整合hibernate 使用spring管理hibernate二级缓存,配置hibernate4.0以上二级缓存
ssh整合hibernate 使用spring管理hibernate二级缓存,配置hibernate4.0以上二级缓存 hibernate : Hibernate是一个持久层框架,经常访问物理数据库 ...
- Hibernate二级缓存攻略
Hibernate二级缓存攻略 很多人对二级缓存都不太了解,或者是有错误的认识,我一直想写一篇文章介绍一下hibernate的二级缓存的,今天终于忍不住了. fi9-DVR] 我的经验主要来自hi ...
- Hibernate二级缓存的使用
1启用Hibernate二级缓存 Hibernate二级缓存分为两部分,class缓存和查询缓存,其获取对象的方式有所不同,但两者也有联系,查询缓存必须以class缓存为基础才能起作用,否则只会使效率 ...
- Hibernate 二级缓存使用
1启用Hibernate二级缓存 Hibernate二级缓存分为两部分,class缓存和查询缓存,其获取对象的方式有所不同,但两者也有联系,查询缓存必须以class缓存为基础才能起作用,否则只会使效率 ...
- Hibernate EHCache - Hibernate二级缓存
Hibernate EHCache - Hibernate二级缓存 欢迎使用Hibernate二级缓存示例教程.今天我们将研究Hibernate EHCache,它是最受欢迎的Hibernate二级缓 ...
- 配置Hibernate二级缓存步骤
配置Hibernate二级缓存步骤: 加入二级缓存的jar包及配置文件 jar包位置:hibernate-release-4.1.8.Final\lib\optional\ehcache下所有jar包 ...
- Hibernate二级缓存问题
相关概念和定义 1.缓存的意义 把一些不常修改,但是又经常用的数据存放到内存中,这样能减少与数据库的交互,提升程序的性能 2.Hibernate中提供了两级缓存: 第一级别的缓存是Session级别的 ...
最新文章
- STM32 进阶教程 9 - 芯片维一码(UID)读取
- 设置ComboBox控件的提示内容.
- Java学习日报—2021/11/18
- “东哥”之后,京东再申请“强东”商标
- 特斯拉拦不住蔚来取代BBA的心
- 【报告分享】中国物联网平台产业市场研究报告(2020版).pdf(附下载链接)...
- MNIST数据集下载与读取
- 计算机软件系统验收标准,软件相关标准目录.xlsx
- 微信科室预约挂号小程序
- Windows 7下面安装VMware、BackTrack5(BT5)、minidwep-gtk
- 旋律生成算法的现状与挑战
- js获取PC设备信息,js获取手机设备信息,最全
- InnoDB之redo log
- 服务产品化,或许是中国软件的出路
- 求二叉树的深度 题目编号:376
- mosquitto简介和使用
- cdh 简介_CDH的介绍和部署
- 西游记中神兽谛听的能力 这款小程序也有
- phpexcel导出大量数据合并单元格_PHPExcel处理一个单元格内多条数据拆分成多个单元格多条数据...
- 【手把手教你】使用Logistic回归、LDA和QDA模型预测指数涨跌