一、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中加入:
- < 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:
- < ehcache>
-
-
< diskStore path="java.io.tmpdir"/>
-
-
-
< defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" />
-
-
-
< cache name="goncha.hb.bean.Person" maxElementsInMemory="10" eternal="false"
-
-
timeToIdleSeconds="100" timeToLiveSeconds="100" overflowToDisk="false" />
-
-
< cache name="goncha.hb.bean.Address" maxElementsInMemory="10" eternal="false"
-
-
timeToIdleSeconds="100" timeToLiveSeconds="100" overflowToDisk="false" />
-
-
< /ehcache>
分享到:
相关推荐
Hibernate缓存分类** Hibernate提供了两级缓存: - **一级缓存**:这是SessionFactory级别的缓存,也是每个Session实例内部的缓存。一级缓存是事务范围的,即每个事务都有自己独立的一级缓存,当事务结束时,该...
1-2 Hibernate缓存分类 Hibernate提供了两层级的缓存: - 一级缓存:这是Session级别的缓存,也称为事务范围缓存。每个Session有自己的缓存,生命周期与Session相同,数据在内存中存储,只被当前Session访问。 - 二...
#### 三、缓存的分类 在Hibernate框架中,主要涉及到两种缓存机制: 1. **一级缓存(First-Level Cache)** - **定义**:一级缓存是由`Session`提供的,其生命周期与`Session`一致。当`Session`关闭时,一级缓存...
**缓存分类**:Hibernate提供了两级缓存。 1. **一级缓存**:也称为Session缓存,位于单个Session实例级别,是默认开启且无法关闭的。它在内存中存储了与Session相关的对象,当Session关闭时,缓存也随之销毁。 2. *...
1-2 Hibernate缓存分类: 一级缓存是事务范围的缓存,它只对当前事务可见,生命周期与事务同步。当事务结束,一级缓存中的数据也会被清除。一级缓存由Hibernate自动管理,开发者一般不需要直接操作。 二级缓存则...
## Hibernate缓存机制详解 ### 一、缓存分类与管理 Hibernate提供了两种主要的缓存类型:一级缓存和二级缓存。 #### 1. 一级缓存 一级缓存也称为Session缓存,它在同一个Session中对数据的多次读取操作只需要一...
《使用Hibernate缓存数据》 在Java开发中,Hibernate是一个广泛应用的对象关系映射(ORM)框架,它极大地简化了数据库操作。为了提高性能,Hibernate引入了缓存机制,有效地减少了与数据库的交互次数,从而提升了...
### Hibernate缓存机制详解 #### 一、概述 Hibernate 是一款流行的 Java 持久层框架,它简化了 Java 应用程序与数据库交互的过程。然而,直接使用 JDBC 访问数据库存在一定的性能开销。为了提升性能,Hibernate ...
3. Hibernate 缓存分类:Hibernate 的缓存包括 Session 的缓存和 SessionFactory 的缓存,其中 SessionFactory 的缓存又可以分为两类:内置缓存和外置缓存。 4. Session 缓存:Session 的缓存是内置的,不能被卸载,...
#### 三、Hibernate缓存分类及特性 - **一级缓存**:这是一种事务级别的缓存,其生命周期与`Session`相同。当`Session`关闭或`SessionFactory`关闭时,一级缓存也会随之失效。一级缓存主要用于减少数据库的读取操作...
#### 三、Hibernate缓存的分类 Hibernate 提供了两种类型的缓存:一级缓存和二级缓存。这两种缓存各有特点,适用于不同的场景。 1. **一级缓存**(Session 缓存) - **定义**:这是 Hibernate 内置的一种缓存机制...
**Hibernate缓存管理详解** 在Java的持久化框架中,Hibernate是一个非常重要的工具,它极大地简化了数据库操作。其中,缓存管理是Hibernate的核心特性之一,对于提高应用程序性能有着显著的作用。本文将深入探讨...
二级缓存分类 Hibernate的二级缓存主要分为以下几类: - **集合缓存**:缓存一对多或一对一关联的集合对象。 - **实体缓存**:缓存单独的持久化实体对象。 - **查询缓存**:缓存查询结果,避免重复执行相同的HQL或...
`hibernate_query_cache`和`hibernate_cache_level_2`揭示了Hibernate的缓存机制。查询缓存可以存储查询结果,避免重复计算,提高效率;第二级缓存是进程级别的,可以跨会话共享数据,进一步提升性能。理解并适当地...
- **缓存机制**:为了提高性能,Hibernate引入了不同级别的缓存机制,如一级缓存、二级缓存等,能够显著减少数据库访问次数。 ##### 3. 查询语言 Hibernate支持两种查询方式:HQL(Hibernate Query Language)和...
#### Hibernate简介 Hibernate是一种“对象/关系映射”(Object/Relational Mapping,简称ORM)技术,它解决了Java对象模型与关系数据库模型之间的不匹配问题。传统的数据库编程需要在代码中直接编写SQL语句,而...
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 ...