`
Rambing
  • 浏览: 31967 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Hibernate的二级缓存

阅读更多
Hibernate的二级缓存
  SessionFactory级别的全局缓存,它底下可以使用不同的缓存类库,比如ehcache、oscache等,需要设置 hibernate.cache.provider_class。如果使用查询缓存,加上 hibernate.cache.use_query_cache=true 缓存可以简单的看成一个Map,通过key在缓存里面找value。
  Hibernate的二级缓存细分为CLASS缓存,查询缓存和COLLECTION缓存。

1. CLASS缓存
当Hibernate的二级缓存被打开时,当任何一个已经配置缓存的对象被加载时候,都会被缓存到其二级缓存中。不论是执行list,iterator方法。不同的是list方法不会从二级缓存中加载数据(如果不使用查询缓存),每次执行都是去数据库直接抽取。而iterator方法因为使用的是延迟加载的策略,所以第一次加载的时候并未真正的加载数据,而是只加载了其中的ID,并且生成一个代理对象。而当对象被使用(也就是调用非getID方法)的时候,如果数据已经在缓存中,则从缓存中取出,否则真正执行SELECT方法从数据库加载数据(Iterator的方式类似于Load方法,只是Iterator先查询出所有的对象的ID,然后根据ID生成代理对象)。

2. 查询缓存
  Hibernate二级缓存的缓存需要配置hibernate.cache.use_query_cache=true。在代码中使用query.setCacheable(true)激活查询缓存。对于查询缓存来说,缓存的key是根据hql生成的sql,再加上参数等信息的QueryKey对象进行管理。而缓存的value,并不是整个结果集,而是查询出来的这一串ID。第一次查询的时候, list执行一条SQL语句查询出所有的结果集,然后从结果集中取出其中的ID的集合作为该查询缓存的Value进行缓存。并且将相应的对象放入CLASS缓存中,并且返回整个结果集。到同样条件第二次查询的时候,先从查询缓存中取出这些ID,然后根据ID到Class缓存中取出具体的对象,并且返回。
对于List方法的查询缓存关键是使用查询语句缓存了ID,然后使用ID进行GET方法查找,那么这样就可以有效的使用Hiberante的一级和二级缓存了。注意Iterator方法因为使用的是延迟加载策略实现,所以Iterator方法不会使用查询缓存(即使显示的调用了query.setCacheable(true)也是没有任何效果的)。
  对于查询缓存的过期维护,Hibernate会再查询缓存的VALUE结果集中维护一个查询缓存的建立时间。每次使用查询缓存之前都会先Check在该缓存时间之后是否有更新该表的操作。如果存在更新那么就放弃查询缓存结果。

3. COLLECTION缓存
Hibernate的Collection元素的缓存 需要在hbm的collection里面设置 <cache usage="***"> 。Collection的缓存和前面查询缓存的list一样,也是只保持一串id,但它不会因为这个表更新过就失效,一个collection缓存 仅在这个collection里面的元素有增删时才失效。 这样有一个问题,如果你的collection是根据某个字段排序的,当其中一个元素更新了该字段时,导致顺序改变时,collection缓存 里面的排序不会做更新。

个人感觉学习这块内容最好的方法是写一个简单的代码,然后debug跟踪看Hiberate的内部实现方法。下面添上一段代码,是Hibernate使用缓存的核心代码:
protected Object doLoad(
			final LoadEvent event,
			final EntityPersister persister,
			final EntityKey keyToLoad,
			final LoadEventListener.LoadType options) throws HibernateException {
  Object entity = loadFromSessionCache( event, keyToLoad, options );
  if ( entity == REMOVED_ENTITY_MARKER ) {
    log.debug( "load request found matching entity in context, but it is scheduled for removal; returning null" );
    return null;
  }
  if ( entity == INCONSISTENT_RTN_CLASS_MARKER ) {
    log.debug( "load request found matching entity in context, but the matched entity was of an inconsistent return type; returning null" );
    return null;
  }
  if ( entity != null ) {
    if ( log.isTraceEnabled() ) {
	log.trace("resolved object in session cache: " +  MessageHelper.infoString( persister, event.getEntityId(), event.getSession().getFactory()  ) );
    }
    return entity;
  }

  entity = loadFromSecondLevelCache(event, persister, options);
  if ( entity != null ) {
    if ( log.isTraceEnabled() ) {
      log.trace("resolved object in second-level cache: " +
	MessageHelper.infoString( persister, event.getEntityId(), event.getSession().getFactory() ) );
    }
    return entity;
  }

  if ( log.isTraceEnabled() ) {
    log.trace("object not resolved in any cache: " +
	MessageHelper.infoString( persister, event.getEntityId(), event.getSession().getFactory() ));
  }

  return loadFromDatasource(event, persister, keyToLoad, options);
}
分享到:
评论

相关推荐

    Hibernate二级缓存

    Hibernate二级缓存是一种提高应用程序性能的技术,它将数据存储在SessionFactory级别的缓存中,使得数据可以在不同的Session之间共享。这与一级缓存(Session级别)不同,一级缓存仅存在于单个Session生命周期内,当...

    hibernate 二级缓存详解

    Hibernate 二级缓存是针对SessionFactory级别的全局缓存,与一级缓存(Session级别)不同,一级缓存只在单个Session生命周期内有效。二级缓存则允许不同Session之间共享数据,提高了数据访问效率,减少了对数据库的...

    hibernate二级缓存

    Hibernate 二级缓存是一种高效的数据存储机制,它能够显著提升Web应用的性能,尤其是在处理大量数据流动时。缓存的主要目标是减少应用与数据库之间的交互次数,从而降低延迟并减轻数据库服务器的压力。在Hibernate...

    Hibernate 二级缓存

    Hibernate 二级缓存

    hibernate二级缓存实例

    在这个"hibernate二级缓存实例"中,我们将深入探讨二级缓存的原理、配置以及在实际项目中的应用。 首先,我们需要了解一级缓存和二级缓存的区别。一级缓存是Session级别的,每个Session都有自己的一级缓存,用于...

    hibernate二级缓存示例源码

    **hibernate二级缓存详解** Hibernate作为Java领域中广泛使用的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,在处理大量数据时,性能优化显得尤为重要,这就是二级缓存的作用。本文将深入探讨Hibernate...

    Hibernate 二级缓存 总结整理

    **Hibernate 二级缓存总结整理** 在Java的持久化框架中,Hibernate是一个广泛使用的ORM(对象关系映射)工具,它极大地简化了数据库操作。在处理大数据量或高并发的场景下,为了提高性能和减少数据库负载,...

    hibernate二级缓存包

    Hibernate二级缓存是Java开发中使用Hibernate框架进行数据持久化时优化性能的一种重要技术。它在一级缓存(Session级别的缓存)的基础上,提供了一个全局的、跨会话的数据存储层,可以显著减少对数据库的访问,从而...

    hibernate二级缓存java包下载

    二级缓存是 Hibernate 缓存策略的一部分,它在应用程序的多个会话之间共享数据,进一步优化了数据库访问效率。 二级缓存分为以下关键知识点: 1. **一级缓存与二级缓存的区别**: - 一级缓存:每个 Hibernate ...

    hibernate 二级缓存

    本篇文章将深入探讨Hibernate二级缓存的概念、工作原理以及如何在实际项目中设置和使用。 **一、二级缓存概念** 一级缓存是每个Hibernate Session内部的一个内存区域,用于存储Session期间的操作对象。当Session...

    hibernate二级缓存所需要的 jar包

    本篇将详细介绍Hibernate二级缓存的概念、作用以及所需jar包的作用。 一、Hibernate二级缓存概念 Hibernate的一级缓存是指Session级别的缓存,每个Session内部都有一个一级缓存,用于存储实体对象,当Session关闭时...

    day37 05-HIbernate二级缓存:一级缓存更新同步到二级缓存及二级缓存配置文件

    本篇文章将深入探讨Hibernate的二级缓存机制,以及如何进行一级缓存与二级缓存的同步,同时还会介绍二级缓存的配置文件设置。 一级缓存是Hibernate默认提供的缓存,每个SessionFactory实例都有一个一级缓存。当对象...

Global site tag (gtag.js) - Google Analytics