对Hibernate缓存策略的理解和应用

引自:http://www.blogjava.net/frostwood/archive/2010/01/06/308465.html

Hibernate提供了三个级别的缓存策略:Session缓存(基本的事务级缓存),Query Cache(查询缓存),Seond-Level Cache(二级缓存)

Session缓存(First-Level Cache):Session是Hibernate用于管理持久化对象的核心机制,它是针对持久性数据的事务级缓存。PersistenceContext中包括:

entityKeys,collectionKeys,

insertion,updates,deletions,

collectionCreations,collectionRemovals,collectionUpdates

由此可见,Session不会把所有的持久化对象实体本身缓存,而只是缓存实体或Collection的Identiy值,和状态被更新过的实体或Collection(包括插入,更新,删除)

当Session中缓存的内容过多时会导致OutOfMemory的问题,可以通过两种方式删除缓存的内容:

  • clear(): 清除所有Session缓存;
  • evict(PersistentObject): 将一个特定持久化对象从Session缓存中删除。

Query Cache:Hibernate可以对频繁进行的查询(相同查询,相同参数)进行缓存以提高效率。但是查询缓存不会缓存结果集中实际的数据实体,而是只缓存Identiy值和结果值类型,因此它应该总是和二级缓存一起使用。但由于实际环境中完全相同的频繁查询很少,所以默认该缓存是disabled的。可以通过两种方式使之生效:(个人觉得这个缓存意义不大)

配置属性:<prop key="hibernate.cache.use_query_cache">true</prop>

代码:Query.setCacheable(true)

Second-Level Cache:  二级缓存,用于对持久化对象实体或Collection的实际数据进行缓存,用于提供一个集群级别(cluster level),JVM级别,或文件系统级的缓存机制。Hibernate的二级缓存通常都是由第三方的开源项目提供,可以通过配置选择特定的缓存实现,例如:EHCache,OSCache,JBoss Cable等。

配置属性:<prop key="hibernate.cache.provider_class">org.hibernate.cache.OSCacheProvider</prop>

二级缓存同样可以通过两种方式来管理:

配置属性:<prop key="hibernate.cache.use_second_level_cache">false</prop>

代码:Query.setCacheMode(CacheMode.IGNORE) (或者GET,NORMAL,PUT,REFRESH)

  • IGNORE: 禁用二级缓存
  • NORMAL: 启用二级缓存,正常读写
  • GET: 只从二级缓存读,除非有数据update
  • PUT: 只向二级缓存写
  • REFRESH: 强制对写入二级缓存的内容进行刷新

最后,在程序调试中,我们可能需要查看各种Cache中实际缓存的内容,可以通过配置属性让Hibernate收集缓存统计信息。当我们遭遇可能由于缓存导致的问题时,这一方法特别有用。

配置属性:<prop key="hibernate.generate_statistics">true</prop>

在代码中获得统计信息:sessionFactory.getStatistics()

时间: 2024-10-08 21:08:08

对Hibernate缓存策略的理解和应用的相关文章

Hibernate(四)——缓存策略+lazy

Hibernate作为和数据库数据打交道的框架,自然会设计到操作数据的效率问题,而对于一些频繁操作的数据,缓存策略就是提高其性能一种重要手段,而Hibernate框架是支持缓存的,而且支持一级和二级两种缓存,合理的使用缓存策略可以大大提高我们的操作数据效率,但是利用不能,可能会造成不必要的麻烦.  一,一级缓存(Session缓存):  Session缓存表示将查询结果放置到Session的临时存储空间(一级缓存中).Hibernate框架默认支持一级缓存的.一级缓存的范围较小,一旦Sessio

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Ehcache 实现 Hibernate 二级缓存策略

1.条件查询的时候,总是发出一条select * from table_name where ....  (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象. 2.把获得的所有数据对象根据ID放入到第二级缓存中. 3.当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查:查不到,如果配置了二级缓存,那么从二级缓存中查:查不到,再查询数据库,把结果按照ID放入到缓存. 4.删除.更新.增加数据的时候,同时更新缓存. Hibernate的二级缓存策略,是针

Hibernate缓存原理与策略

Hibernate缓存原理: 对于Hibernate这类ORM而言,缓存显的尤为重要,它是持久层性能提升的关键.简单来讲Hibernate就是对JDBC进行封装,以实现内部状态的管理,OR关系的映射等,但随之带来的就是数据访问效率的降低,和性能的下降,而缓存就是弥补这一缺点的重要方法. 缓存就是数据库数据在内存中的临时容器,包括数据库数据在内存中的临时拷贝,它位于数据库与数据库访问层中间.ORM在查询数据时首先会根据自身的缓存管理策略,在缓存中查找相关数据,如发现所需的数据,则直接将此数据作为结

Hibernate的二级缓存策略

Hibernate的二级缓存策略的一般过程如下: 1) 条件查询的时候,总是发出一条select * from table_name where …. (选择所有字段)这样的SQL语句查询数据库,一次获得所有的数据对象. 2) 把获得的所有数据对象根据ID放入到第二级缓存中. 3) 当Hibernate根据ID访问数据对象的时候,首先从Session一级缓存中查:查不到,如果配置了二级缓存,那么从二级缓存中查:查不到,再查询数据库,把结果按照ID放入到缓存. 4) 删除.更新.增加数据的时候,同

三大框架 之 Hibernate生成策略与缓存策略(主键生成策略、持久化、持久化类划分、一级缓存、事物管理)

目录 Hibernate生成策略与缓存策略 主键生成策略 主键分类 主键的生成策略 持久化 什么是持久化 什么是持久化类 持久化类编写规则 持久化类的划分 三种状态区分 持久态对象特征 一级缓存 什么是缓存 一级缓存 一级缓存特点 一级缓存内部结构 事务管理 什么是事务 事务特性 事务的隔离级别 Hibernate设置事务的隔离级别 事务业务层连接 Hibernate生成策略与缓存策略 主键生成策略 主键分类 自然主键 主键本身就是表中的一个字段 实体中一个具体的属性,对象本身唯一的特性 创建一

理解Java Integer的缓存策略

转载自http://www.importnew.com/18884.html 本文将介绍 Java 中 Integer 缓存的相关知识.这是 Java 5 中引入的一个有助于节省内存.提高性能的特性.首先看一个使用 Integer 的示例代码,展示了 Integer 的缓存行为.接着我们将学习这种实现的原因和目的.你可以先猜猜下面 Java 程序的输出结果.很明显,这里有一些小陷阱,这也是我们写这篇文章的原因. public class JavaIntegerCache { public sta

【转】理解Java Integer的缓存策略

本文将介绍 Java 中 Integer 缓存的相关知识.这是 Java 5 中引入的一个有助于节省内存.提高性能的特性.首先看一个使用 Integer 的示例代码,展示了 Integer 的缓存行为.接着我们将学习这种实现的原因和目的.你可以先猜猜下面 Java 程序的输出结果.很明显,这里有一些小陷阱,这也是我们写这篇文章的原因. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 package com.javapaper

10.hibernate缓存机制详细分析(转自xiaoluo501395377)

hibernate缓存机制详细分析 在本篇随笔里将会分析一下hibernate的缓存机制,包括一级缓存(session级别).二级缓存(sessionFactory级别)以及查询缓存,当然还要讨论下我们的N+1的问题. 随笔虽长,但我相信看完的朋友绝对能对hibernate的 N+1问题以及缓存有更深的了解. 一.N+1问题 首先我们来探讨一下N+1的问题,我们先通过一个例子来看一下,什么是N+1问题: list()获得对象: 1 /** 2 * 此时会发出一条sql,将30个学生全部查询出来