`
javaeyetodj
  • 浏览: 431458 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Hibernate缓存简介及分类

阅读更多

一、Hibernate缓存简介  Cache In Hibernate

HIBERNATE中的CACHE有两级.

一级是在Session范围内的CACHE. 即每个Session有自己的一个CACHE, 当前操作的对象都会被保留在CACHE中. 但是Session关闭后这个CACHE也就没有. 可见这级CACHE的生命期是很短的. (使用id进行关键字存储:缓存的key就是ID,value是POJO)(缓存的是实体对象)

另一级CACHE是在SessionFactory范围的, 可以被来自同一个SessionFactory的Session共享. 在HIBERNATE的文档中称其为SECOND LEVEL CACHE. 显然后者的优势较明显, 也比较复合当前的使用环境.   它可以使用不同的缓存实现,如EhCache、JBossCache、OsCache等 (二级缓存是缓存实体对象的)

还有一个类型的CACHE就是QueryCache. 它的作用就是缓存一个Query以及Query返回对象的Identifier以及对象的类型. 有了QueryCache后就可以高效的使用SECOND LEVEL CACHE.

hibernate缓存查询(hibernate默认是关闭的)
查询缓存是针对普通属性结果集的缓存
对实体对象的结果集只缓存id
查询缓存的生命周期,当前关联的表发生修改,那么查询缓存生命周期结束

查询缓存的配置和使用:

1. 启用查询缓存:在hibernate.cfg.xml中加入:

  1. < property name=”hibernate.cache.use_query_cache”>true< /property>   

2. 在程序中必须手动启用查询缓存,如:query.setCacheable(true);

QueryCache用来缓存查询语句, 及查询结果集中对象的Identifier与Type. 当再次使用已缓存的Query时, 就可以通过对象的Identifier与Type在SECOND LEVEL CACHE中查找实际的对象.

对于查询缓存来说,缓存的key是根据hql生成的sql,再加上参数,分页等信息(可以通过日志输出看到,不过它的输出不是很可读,最好改一下它的代码)。

注:一级缓存也叫session级的缓存或事务缓存。Hibernate二级缓存也称为进程级的缓存或SessionFactory级的缓存。二级缓存是全局缓存,它可以被所有的session共享。二级缓存的生命周期和SessionFactory的生命周期一致,SessionFactory可以管理二级缓存。

二、Hibernate缓存的范围

Hibernate缓存的范围分为3类:
1.事务范围
事务范围的缓存只能被当前事务访问,每个事务都有各自的缓存,缓存内的数据通常采用相互关联的对象形式.缓存的生命周期依赖于事务的生命周期,只有当事务结束时,缓存的生命周期才会结束.事务范围的缓存使用内存作为存储介质,一级缓存就属于事务范围.
2.应用范围
应用程序的缓存可以被应用范围内的所有事务共享访问.缓存的生命周期依赖于应用的生命周期,只有当应用结束时,缓存的生命周期才会结束.应用范围的缓存可以使用内存或硬盘作为存储介质,二级缓存就属于应用范围.
3.集群范围
在集群环境中,缓存被一个机器或多个机器的进程共享,缓存中的数据被复制到集群环境中的每个进程节点,进程间通过远程通信来保证缓存中的数据的一致,缓存中的数据通常采用对象的松散数据形式.

三、Hibernate缓存的方式

有四种,分别为:

CacheConcurrencyStrategy.NONE

CacheConcurrencyStrategy.READ_ONLY,只读模式,在此模式下,如果对数据进行更新操作,会有异常;

CacheConcurrencyStrategy.READ_WRITE,读写模式在更新缓存的时候会把缓存里面的数据换成一个锁,其它事务如果去取相应的缓存数据,发现被锁了,直接就去数据库查询;

CacheConcurrencyStrategy.NONSTRICT_READ_WRITE,不严格的读写模式则不会的缓存数据加锁;

CacheConcurrencyStrategy.TRANSACTIONAL,事务模式指缓存支持事务,当事务回滚时,缓存也能回滚,只支持JTA环境。

缓存的注释写法如下,加在Entity的java类上:

@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)

四、Hibernate缓存的管理

一级缓存的管理:
evit(Object obj)  将指定的持久化对象从一级缓存中清除,释放对象所占用的内存资源,指定对象从持久化状态变为脱管状态,从而成为游离对象. 
clear()  将一级缓存中的所有持久化对象清除,释放其占用的内存资源 
contains(Object obj) 判断指定的对象是否存在于一级缓存中. 
flush() 刷新一级缓存区的内容,使之与数据库数据保持同步.

二级缓存的管理:    

evict(Class arg0, Serializable arg1)  将某个类的指定ID的持久化对象从二级缓存中清除,释放对象所占用的资源.

evictCollection(String arg0)  将指定类的所有持久化对象的指定集合从二级缓存中清除,释放其占用的内存资源.

如何避免一次性大量的实体数据入库导致内存溢出
*先flush,再clear

如果数据量特别大,考虑采用jdbc实现,如果jdbc也不能满足要求,可以考虑采用数据库本身的特定导入工具

五、什么样的数据不适合放在二级缓存中来? 

下面这几种情况就不适合加载到二级缓存中: 
1.经常被修改的数据 
2.绝对不允许出现并发访问的数据 
3.与其他应用共享的数据 
下面这己种情况合适加载到二级缓存中: 
1.数据更新频率低 
2.允许偶尔出现并发问题的非重要数据 
3.不会被并发访问的数据 
4.常量数据 
5.不会被第三方修改的数据

六、二级缓存的配置

Hibernate的二级缓存功能是靠配置二级缓存插件来实现的,Hibernate为了集成这些插件,Hibernate提供了org.hibernate.cache.CacheProvider借口,它充当缓存插件与Hibernate之间的适配器 .

常用的二级缓存插件
EHCache  org.hibernate.cache.EhCacheProvider
OSCache  org.hibernate.cache.OSCacheProvider
SwarmCahe  org.hibernate.cache.SwarmCacheProvider
JBossCache  org.hibernate.cache.TreeCacheProvider

设置hibernate.cache.provider_class。

我们这里用ehcache,如
hibernate.cache.provider_class=net.sf.hibernate.cache.EhCacheProvider
由于这是HIBERNATE默认的CACHE提供者, 所以无须做什么设置.

只要在src中添加ehcache的配置文件ehcache.xml:

  1. < ehcache>   
  2.  
  3.     < diskStore path="java.io.tmpdir"/>    
  4.  
  5.  
  6.     < defaultCache   maxElementsInMemory="10000"   eternal="false"  timeToIdleSeconds="120"          timeToLiveSeconds="120"  overflowToDisk="true"   />     
  7.  
  8.  
  9.     < cache name="goncha.hb.bean.Person"   maxElementsInMemory="10"       eternal="false"      
  10.  
  11.         timeToIdleSeconds="100"  timeToLiveSeconds="100"  overflowToDisk="false"   />       
  12.  
  13.       < cache name="goncha.hb.bean.Address"  maxElementsInMemory="10"     eternal="false"      
  14.  
  15.         timeToIdleSeconds="100"  timeToLiveSeconds="100"  overflowToDisk="false"    />       
  16.  
  17. < /ehcache>    
分享到:
评论

相关推荐

    Hibernate缓存深入详解

    Hibernate缓存分类** Hibernate提供了两级缓存: - **一级缓存**:这是SessionFactory级别的缓存,也是每个Session实例内部的缓存。一级缓存是事务范围的,即每个事务都有自己独立的一级缓存,当事务结束时,该...

    Hibernate缓存深入详解.ppt

    1-2 Hibernate缓存分类 Hibernate提供了两层级的缓存: - 一级缓存:这是Session级别的缓存,也称为事务范围缓存。每个Session有自己的缓存,生命周期与Session相同,数据在内存中存储,只被当前Session访问。 - 二...

    Hibernate的缓存策略

    #### 三、缓存的分类 在Hibernate框架中,主要涉及到两种缓存机制: 1. **一级缓存(First-Level Cache)** - **定义**:一级缓存是由`Session`提供的,其生命周期与`Session`一致。当`Session`关闭时,一级缓存...

    hibernate 缓存

    **缓存分类**:Hibernate提供了两级缓存。 1. **一级缓存**:也称为Session缓存,位于单个Session实例级别,是默认开启且无法关闭的。它在内存中存储了与Session相关的对象,当Session关闭时,缓存也随之销毁。 2. *...

    Hibernate缓存

    1-2 Hibernate缓存分类: 一级缓存是事务范围的缓存,它只对当前事务可见,生命周期与事务同步。当事务结束,一级缓存中的数据也会被清除。一级缓存由Hibernate自动管理,开发者一般不需要直接操作。 二级缓存则...

    Hibernate缓存机制解说

    ## Hibernate缓存机制详解 ### 一、缓存分类与管理 Hibernate提供了两种主要的缓存类型:一级缓存和二级缓存。 #### 1. 一级缓存 一级缓存也称为Session缓存,它在同一个Session中对数据的多次读取操作只需要一...

    使用Hibernate缓存数据.ppt

    《使用Hibernate缓存数据》 在Java开发中,Hibernate是一个广泛应用的对象关系映射(ORM)框架,它极大地简化了数据库操作。为了提高性能,Hibernate引入了缓存机制,有效地减少了与数据库的交互次数,从而提升了...

    Hibernate缓存机制探讨.doc

    ### Hibernate缓存机制详解 #### 一、概述 Hibernate 是一款流行的 Java 持久层框架,它简化了 Java 应用程序与数据库交互的过程。然而,直接使用 JDBC 访问数据库存在一定的性能开销。为了提升性能,Hibernate ...

    hibernate二级缓存

    3. Hibernate 缓存分类:Hibernate 的缓存包括 Session 的缓存和 SessionFactory 的缓存,其中 SessionFactory 的缓存又可以分为两类:内置缓存和外置缓存。 4. Session 缓存:Session 的缓存是内置的,不能被卸载,...

    详解Hibernate的缓存机制及其配置代码

    #### 三、Hibernate缓存分类及特性 - **一级缓存**:这是一种事务级别的缓存,其生命周期与`Session`相同。当`Session`关闭或`SessionFactory`关闭时,一级缓存也会随之失效。一级缓存主要用于减少数据库的读取操作...

    hibernate缓存

    #### 三、Hibernate缓存的分类 Hibernate 提供了两种类型的缓存:一级缓存和二级缓存。这两种缓存各有特点,适用于不同的场景。 1. **一级缓存**(Session 缓存) - **定义**:这是 Hibernate 内置的一种缓存机制...

    Hibernate 缓存管理

    **Hibernate缓存管理详解** 在Java的持久化框架中,Hibernate是一个非常重要的工具,它极大地简化了数据库操作。其中,缓存管理是Hibernate的核心特性之一,对于提高应用程序性能有着显著的作用。本文将深入探讨...

    Hibernate二级缓存架包.rar

    二级缓存分类 Hibernate的二级缓存主要分为以下几类: - **集合缓存**:缓存一对多或一对一关联的集合对象。 - **实体缓存**:缓存单独的持久化实体对象。 - **查询缓存**:缓存查询结果,避免重复执行相同的HQL或...

    Hibernate 经典例子全

    `hibernate_query_cache`和`hibernate_cache_level_2`揭示了Hibernate的缓存机制。查询缓存可以存储查询结果,避免重复计算,提高效率;第二级缓存是进程级别的,可以跨会话共享数据,进一步提升性能。理解并适当地...

    Java Persistence with Hibernate

    - **缓存机制**:为了提高性能,Hibernate引入了不同级别的缓存机制,如一级缓存、二级缓存等,能够显著减少数据库访问次数。 ##### 3. 查询语言 Hibernate支持两种查询方式:HQL(Hibernate Query Language)和...

    Hibernate电子书(全)

    #### Hibernate简介 Hibernate是一种“对象/关系映射”(Object/Relational Mapping,简称ORM)技术,它解决了Java对象模型与关系数据库模型之间的不匹配问题。传统的数据库编程需要在代码中直接编写SQL语句,而...

    Hibernate+中文文档

    3.5. Hibernate缓存属性 3.6. Hibernate事务属性 3.7. 其他属性 3.8. Hibernate SQL方言 (hibernate.dialect) 3.9. Hibernate日志类别 3.10. JTA TransactionManagers 9.1. 继承映射特性(Features of ...

Global site tag (gtag.js) - Google Analytics