`
jddlcg
  • 浏览: 9581 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

学习Hibernate之数据缓存

阅读更多

    对于Hibernate这类ORM而言,缓存显的尤为重要,它是持久层性能提升的关键.简单来讲Hibernate就是对JDBC进行封装,以实现内部状态的管理,OR关系的映射等,但随之带来的就是数据访问效率的降低,和性能的下降,而缓存就是弥补这一缺点的重要方法.

    缓存就是数据库数据在内存中的临时容器,包括数据库数据在内存中的临时拷贝,它位于数据库与数据库访问层中间.ORM在查询数据时首先会根据自身的缓存管理策略,在缓存中查找相关数据,如发现所需的数据,则直接将此数据作为结果加以利用,从而避免了数据库调用性能的开销.而相对内存操作而言,数据库调用是一个代价高昂的过程.

    一般来讲ORM中的缓存分为以下几类:

        1.事务级缓存:即在当前事务范围内的数据缓存.就Hibernate来讲,事务级缓存是基于Session的生命周期实现的,每个Session内部会存在一个数据缓存,它随着Session的创建而存在,随着Session的销毁而灭亡,因此也称为Session Level Cache.

        2.应用级缓存:即在某个应用中或应用中某个独立数据库访问子集中的共享缓存,此缓存可由多个事务共享(数据库事务或应用事务),事务之间的缓存共享策略与应用的事务隔离机制密切相关.在Hibernate中,应用级缓存由SessionFactory实现,所有由一个SessionFactory创建的Session实例共享此缓存,因此也称为SessionFactory Level Cache.

        3.分布式缓存:即在多个应用实例,多个JVM间共享的缓存策略.分布式缓存由多个应用级缓存实例组成,通过某种远程机制(RMI,JMS)实现各个缓存实例间的数据同步,任何一个实例的数据修改,将导致整个集群间的数据状态同步.

    Hibernate数据缓存:

        1.内部缓存(Session Level Cache也称一级缓存):

        举例说明:

java 代码
  1. public class Test {   
  2.   
  3.       public void get(){    
  4.   
  5.             Session session = HibernateSessionFactory.getSession();   
  6.             TUser t = (TUser)session.get("hibernate.TUser"2);   
  7.             System.out.println(t.getName());   
  8.             session.close();   
  9.             }   
  10.   
  11. }   
  12.   

             进行测试:在控制台打印出一条SQL语句:Hibernate: select tuser0_.id as id0_0_, tuser0_.name as name0_0_, tuser0_.sex as sex0_0_ from test.t_user tuser0_ where tuser0_.id=? 说明进行了一次数据库的调用.

      代码更改如下:

  1. public class Test {   
  2.     
  3.       public void get(){   
  4.   
  5.             Session session = HibernateSessionFactory.getSession();   
  6.             TUser t = (TUser)session.get("hibernate.TUser"2);   
  7.             System.out.println(t.getName());   
  8.             TUser tt = (TUser)session.get("hibernate.TUser"2);   
  9.             System.out.println(tt.getName());   
  10.             session.close();   
  11.   
  12.       }   
  13.   
  14. }   
  15.   

       再进行测试:进行了两次查询,控制台仍然只打出一条SQL语句:Hibernate: select tuser0_.id as id0_0_, tuser0_.name as name0_0_, tuser0_.sex as sex0_0_ from test.t_user tuser0_ where tuser0_.id=?  说明还是只进行了一次数据库的调用.

       再将代码更改如下:

  1. public class Test {   
  2.     
  3.       public void get(){    
  4.   
  5.             Session session = HibernateSessionFactory.getSession();   
  6.             TUser t = (TUser)session.get("hibernate.TUser"2);   
  7.             System.out.println(t.getName());   
  8.             session.close();   
  9.             Session session1 = HibernateSessionFactory.getSession();   
  10.             TUser tt = (TUser)session1.get("hibernate.TUser"2);   
  11.             System.out.println(tt.getName());   
  12.             session1.close();   
  13.   
  14.       }   
  15.   
  16.  }   

       继续测试:进行两次查询控制台打印两条SQL语句:Hibernate: select tuser0_.id as id0_0_, tuser0_.name as name0_0_, tuser0_.sex as sex0_0_ from test.t_user tuser0_ where tuser0_.id=?
Hibernate: select tuser0_.id as id0_0_, tuser0_.name as name0_0_, tuser0_.sex as sex0_0_ from test.t_user tuser0_ where tuser0_.id=?

      结论:Hibernate进行查询时总是先在缓存中进行查询,如缓存中没有所需数据才进行数据库的查询.Hibernate的内部缓存是基于Session的生命周期的,也就是说存在于每个Session内部,它随着Session的创建而存在,随着Session的销毁而灭亡,内部缓存一般由Hibernate自动维护,不需要人为干预,当然我们也可以根据需要进行相应操作:Session.evict(Object)(将指定对象从内部缓存清除),Session.clear()(清空内部缓存).(如在两次查询间加入Session.clear()将会清空内部缓存,使得一个Sesion内部的两次相同的查询要对数据库进行两次操作).

      2.二级缓存:(有时称为SessionFactory Level Cache)

      Hibernate本身并未提供二级缓存的产品化实现(只提供了一个基于HashTable的简单缓存以供调试),这里我使用的是第三方缓存组件:EHcache.Hibernate的二级缓存实现需要进行以下配置(Hibernate3):

      首先在hibernate.cfg.xml内添加:

 

  1. <property name="cache.provider_class">org.hibernate.cache.EhCacheProviderproperty>  
  2. <property name="hibernate.cache.use_query_cache">trueproperty>  
然后在映射文件中添加:
  1. <cache usage="read-only"/>  
<cache usage="read-only"></cache>

            测试上面代码:控制台输出多了这样一句[ WARN] (CacheFactory.java:43) - read-only cache configured for mutable class: hibernate.TUser,二级缓存启用成功!!      

java 代码
  1. public class Test {   
  2.     
  3.       public void executeQuery(){   
  4.      
  5.             List list = new ArrayList();   
  6.             Session session = HibernateSessionFactory.getSession();   
  7.             Query query = session.createQuery("from TUser t");   
  8.             query.setCacheable(true);//激活查询缓存   
  9.             list = query.list();   
  10.             session.close();   
  11.   
  12.       }   
  13.       public void get(){   
  14.   
  15.             Session session = HibernateSessionFactory.getSession();   
  16.             TUser t = (TUser)session.get("hibernate.TUser"2);   
  17.             System.out.println(t.getName());   
  18.             session.close();   
  19.   
  20.      }   
  21.   
  22. }   

      测试:控制台只输出一条SQL语句:Hibernate: select tuser0_.id as id0_, tuser0_.name as name0_, tuser0_.sex as sex0_ from test.t_user tuser0_(即Query query = session.createQuery("from TUser t")这句代码所对应的SQL).  executeQuery()方法与get()方法使用的是不同的Session!!可是executeQuery()方法与get()方法只对数据库进行了一次操作,这就是二级缓存在起作用了.  

      结论:Hibernate二级缓存是SessionFactory级的缓存,它允许多个Session间共享,使用时需要使用第三方的缓存组件,新版Hibernate将EHcache作为默认的二级缓存实现.

      缓存同步策略:缓存同步策略决定了数据对象在缓存中的存取规则,我们必须为每个实体类指定相应的缓存同步策略.Hibernate中提供了4种不同的缓存同步策略:(暂时只记个概念吧)

      1.read-only:只读.对于不会发生改变的数据可使用.

      2.nonstrict-read-write:如果程序对并发访问下的数据同步要求不严格,且数据更新频率较低,采用本缓存同步策略可获得较好性能.

      3.read-write:严格的读写缓存.基于时间戳判定机制,实现了"read committed"事务隔离等级.用于对数据同步要求的情况,但不支持分布式缓存,实际应用中使用最多的缓存同步策略.

      4.transactional:事务型缓存,必须运行在JTA事务环境中.此缓存中,缓存的相关操作被添加到事务中(此缓存类似于一个内存数据库),如事务失败,则缓冲池的数据会一同回滚到事务的开始之前的状态.事务型缓存实现了"Repeatable read"事务隔离等级,有效保证了数据的合法性,适应于对关键数据的缓存,Hibernate内置缓存中,只有JBossCache支持事务型缓存.

 

       注:以上内容整理自<深入浅出Hibernate>
分享到:
评论

相关推荐

    hibernate二级缓存实例

    总的来说,"hibernate二级缓存实例"是一个很好的学习资源,它可以帮助我们理解二级缓存的工作机制,掌握如何在项目中配置和使用,以及注意潜在的问题和优化策略。通过实践,我们可以更好地运用这一技术,提升Java...

    hibernate二级缓存示例源码

    综上所述,通过学习`hibernate二级缓存示例源码`,我们可以了解到如何在实际项目中配置和使用Hibernate二级缓存,从而提升系统的性能。在实际应用中,应结合具体场景选择合适的缓存策略,以达到最佳的性能优化效果。

    hibernate二级缓存java包下载

    Hibernate 是一个非常流行的开源对象关系映射(ORM)框架,它允许 Java 开发人员将数据库操作转换...通过学习这些内容,开发者可以更好地理解并掌握如何在实际项目中有效利用 Hibernate 的二级缓存功能,提升系统性能。

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

    学习和掌握Hibernate的二级缓存机制对于优化大型应用的性能至关重要。通过合理配置和使用,可以在不牺牲数据一致性的情况下,大幅度减少对数据库的访问,提高系统响应速度。在实际项目中,可以根据业务需求和系统...

    Hibernate二级缓存+分页功能

    当数据发生变化时,通过监听Hibernate事件或定时任务更新缓存,确保数据一致性。 总结,理解并熟练运用Hibernate的二级缓存和分页功能,能帮助我们构建高效、稳定的企业级应用。在具体实现时,还需要根据业务需求和...

    hibernate二级缓存 SSH

    而二级缓存则是在多个Session之间共享的数据缓存,它通常由第三方插件如Ehcache或Infinispan提供。二级缓存可以大大提高数据读取速度,因为一旦数据被加载到缓存中,后续的相同查询就可以直接从内存中获取,而不是...

    hibernate二级缓存

    **hibernate二级缓存详解** 在Java的持久化框架Hibernate中,缓存是一种重要的优化手段,它能够显著提升数据库操作的效率。...通过本项目,你可以深入学习这两个缓存层次的工作原理,并通过实际操作来加深理解。

    Hibernate二级缓存

    本篇主要探讨的是Hibernate的二级缓存,这是一种可以跨会话共享的数据存储,对于提高系统性能有着显著的作用。 **一、Hibernate缓存层次** Hibernate缓存主要分为一级缓存和二级缓存: 1. **一级缓存(Session...

    Hibernate-二级缓存总结 开发技术 - Java.zip

    综上所述,Hibernate的二级缓存是提升Java应用程序性能的有效手段,但同时也需要谨慎对待,合理配置和使用,以防止可能带来的数据一致性问题。通过深入学习和实践,开发者能够更好地利用这一特性优化自己的Java应用...

    Hibernate_二级缓存 实验心得,手册

    在学习Hibernate的过程中,二级缓存是一个非常重要的概念。与一级缓存不同的是,一级缓存默认为每个`Session`开启,用于存储当前`Session`内的实体状态。而二级缓存则是在`SessionFactory`级别提供的缓存机制,它...

    Hibernate二级缓存实例.rar

    而Hibernate的二级缓存是其性能优化的重要手段,它为应用程序提供了跨会话的数据缓存能力。这个"Hibernate二级缓存实例"压缩包文件提供了一个实际的示例,帮助我们更好地理解这一概念。 首先,我们需要了解什么是...

    hibernate学习资料大全

    理解ORM的概念是学习Hibernate的第一步。 2. **Hibernate配置**: 在使用Hibernate时,我们需要配置一个名为`hibernate.cfg.xml`的文件,其中包含了数据库连接信息、方言、缓存策略等。学习如何正确配置这些参数...

    Hibernate教程25_Hibernate缓存

    在这个教程中,我们将深入学习Hibernate如何实现缓存,以提高数据访问性能。 **描述分析:** 描述中的链接指向了一个CSDN博客文章,虽然具体内容没有给出,但可以推测它提供了与Hibernate缓存相关的源码示例。这...

    Hibernat一级缓存(源码)

    Hibernate 是一个流行的 Java ORM(对象关系映射)框架,它允许开发者使用面向对象的方式来操作数据库。...提供的 "student" 文件可能包含了关于 Hibernate 一级缓存实现的示例代码,可以进一步帮助理解和学习。

    day37 07-Hibernate二级缓存:查询缓存

    在IT行业中,数据库操作是...在给出的压缩包文件"hibernate3_day03"中,可能包含了与Hibernate二级缓存相关的代码示例、配置文件或者教程文档,进一步的学习和实践可以从这些资源入手,加深对二级缓存的理解和运用。

    Hibernate性能优化:一级缓存

    总之,Hibernate的一级缓存是提高应用程序性能的关键因素之一。理解其工作原理并采取合适的优化措施,不仅能够减少数据库的负载,还能显著提升应用的整体响应速度。通过学习和实践,我们可以更好地驾驭这个强大的...

    41_传智播客hibernate教程_hibernate二级缓存的扩充细节.rar

    在IT行业中,Hibernate是一个非常...通过本教程,你将学习到如何在实际项目中配置和优化Hibernate的二级缓存,以及如何解决与之相关的各种问题。这将有助于提升应用的响应速度,降低数据库压力,提高系统的整体性能。

    Spring4+Hibernate4二级缓存实例源码

    通过这个"Spring4+Hibernate4二级缓存实例源码",你可以学习到如何在实际项目中结合Spring和Hibernate实现二级缓存,提高应用的运行效率。同时,深入理解缓存的工作原理和最佳实践,对于优化系统的性能和架构有着...

    hibernate二级缓存实战之EhCacheProvider

    二级缓存与一级缓存( Hibernate Session 内部的缓存)不同,一级缓存是每个Session独享的,而二级缓存则是跨Session共享的,可以提高多个并发用户访问相同数据时的性能。 首先,我们需要在Hibernate配置文件(通常...

    day37 03-Hibernate二级缓存:集合缓冲区特点

    标题中的“Hibernate二级缓存:集合缓冲区特点”是指在使用Hibernate进行数据库操作时...通过学习这些内容,你可以更深入地理解和应用Hibernate的二级缓存,特别是集合缓冲区的特性,从而提升你的Java应用程序的性能。

Global site tag (gtag.js) - Google Analytics