`
growinglin
  • 浏览: 9154 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

hibernate缓存

阅读更多
hibernate缓存

缓存类型

     一.事务范围:位于当前工作单元,不能并发访问

     二.进程范围:多个工作单元共享,可并发访问,可存储实例本身也可存散列数据,然后在

               重新组装

     三.集群范围:多个进程和主机间访问,网络通信是重点.需要将数据复制到所有集群中的节点.



     缓存和OID:

     事务级缓存也用于对象id的使用范围,是理想的缓存

     进程级缓存可选择实现id的进程范围存储,也和主键对应.并发工作单元查询同一id对象的话返

     回相同的实例.在进程级缓存中的对象也可按值返回,每个工作单元再重新组装形成副本.



Hibernate缓存架构

     1、一级缓存即session.

     2、二级缓存是可配的插件,可用于进程/集群范围缓存.他们缓存都是状态(按值返回),

        而不是真正的持久化对象.对于特定的数据项来说缓存的并发策略定义了事务的 

        隔离细节.每个类或者每个集合的二级缓存是可选可配的.每个缓存都使用了自己

        的缓存区域.

     3、Hibernate还实现了对查询结果集的缓存,他和二级缓存紧密结合.而且需要额外

        的两个物理缓存区域来容纳缓存的查询结果和最后更新表的时间戳.



内置并发策略

     并发策略是调解人,负责在缓存中检索数据.对于特定数据项,他也定义了事务隔离的语义.对类

     或集合来说使用哪个并发策略需要做出判断.

     四个内置的并发策略体现了递减的事务隔离的等级.

     1、Transationsal

        只在受管环境中使用,如果需要可以确保所有的事务隔离到可重复读,很少更新且防止脏数

        据情况下该策略很重要

     2、Read-write

        该策略维护读已提交隔离级别,使用了时间戳机制只在非集群环境下使用.

     3、Nostrict-read-write

        不保证在数据库和缓存之间数据的一致性,如果使用的话,应该配置一个高效短期的过期超

        时.否则,可能读到脏数据.

     4、Read-only

        适用于从不发生改变的数据.只对数据进行引用.约束的降低带来了性能提升.





Hibernate二级缓存

     1、所有通过同一sf开启的会话共享同一二级缓存

     2、对象以拆解的形式存于二级缓存中(拆解是串行化过程,算法更多,更快比java串行)

     3、重点在于缓存方案(缓存策略与物理缓存提供商)

     4、不同数据需要不同的缓存方案.涉及如下设置:

          a、是否开启二级缓存

          b、Hibernate并发策略

          c、缓存过期策略(timerout LRU 内存敏感)

          d、缓存的物理格式(内存索引文件 集群替换)



缓存查询结果

     二级缓存是数据共享缓存,当访问未加载的代理类实例或者集合或者按照oid检索的时

候,hiberante都会到一、二级缓存中进行查找.默认情况下,查询结果是不缓存的.如果通过iterator()

方法进行查询,只从数据库中查询主键值.而实体数据会从一、二级缓存中查找.

     而缓存查询结果是完全不同的问题.他默认是关闭的,每个HQL,JPA QL,SQL和Criteria总是首先要访问数据库。


分享到:
评论

相关推荐

    Hibernate缓存深入详解 from ITEye

    **Hibernate缓存深入详解** 在Java企业级应用开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,随着应用规模的扩大,数据访问性能成为了一个不可忽视的问题。这时,...

    Hibernate缓存技术研究

    ### Hibernate缓存技术研究 #### 一、引言 Hibernate是一种强大的对象-关系映射(Object-Relational Mapping,简称ORM)工具,主要用于Java环境下的应用程序。它能够将应用程序中的对象模型映射到关系型数据库的表...

    Hibernate缓存.doc

    Hibernate缓存.docHibernate缓存.doc

    Java Hibernate缓存深入详解

    Java Hibernate缓存深入详解

    Hibernate缓存与spring事务详解

    **标题:“Hibernate缓存与Spring事务详解”** 在IT领域,尤其是Java开发中,Hibernate作为一款流行的ORM(对象关系映射)框架,极大地简化了数据库操作。而Spring框架则以其全面的功能,包括依赖注入、AOP(面向切...

    hibernate缓存机制

    Hibernate缓存机制是提高应用程序性能的关键技术之一,它通过存储数据副本减少对物理数据库的访问。缓存可以分为两层:第一级缓存和第二级缓存。 **第一级缓存**是内置在Session中的,它是不可卸载的,也称为...

    hibernate缓存深入详解.

    关于hibernate缓存的一个ppt课件,60+幻灯片,有需要的可以看一下

    Hibernate缓存深入详解

    【Hibernate缓存深入详解】 在Java的持久化框架Hibernate中,缓存机制是提升系统性能的关键因素。它位于Hibernate应用和数据库之间,减少了对数据库的直接访问,从而提高了应用程序的运行速度。缓存中存储的是...

    Hibernate缓存详解

    **Hibernate缓存详解** 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。为了提高数据访问性能,Hibernate引入了缓存机制,它可以减少对数据库的直接访问,从而提升应用的...

    Hibernate缓存,性能优化

    本文将深入探讨Hibernate缓存的原理、类型及其对性能优化的影响。 ### Hibernate缓存原理 Hibernate缓存主要分为一级缓存和二级缓存。一级缓存,也称为会话缓存(Session Cache),是默认启用的,由Hibernate自动...

    hibernate缓存和事务

    Hibernate 是一个流行的对象关系映射(ORM)框架,它允许Java...通过理解Hibernate缓存和事务管理,以及如何有效地执行查询,开发者可以创建高效、健壮的Java应用程序,降低与数据库交互的复杂性,同时提升系统性能。

    Hibernate教程25_Hibernate缓存

    **标题解析:** "Hibernate教程25_Hibernate缓存" 这个标题表明了我们要讨论的是关于Hibernate框架的第25个教程,重点是它的缓存机制。Hibernate是一个流行的Java对象关系映射(ORM)框架,它允许开发者用面向对象的...

    Hibernate缓存管理.doc

    【Hibernate缓存管理】是数据库持久化框架Hibernate中优化性能的关键技术。缓存的主要目的是减少对数据库的直接访问,提高应用程序的运行效率。缓存的数据是数据库中数据的副本,存在于内存或硬盘中,便于快速读取。...

    hibernate缓存ehcache用法

    这篇博客文章“hibernate缓存ehcache用法”可能详细介绍了如何在Hibernate中配置和使用Ehcache。 首先,我们需要理解什么是缓存。缓存是一种存储技术,用于临时保存经常访问的数据,以减少对主存储器(如数据库)的...

    hibernate 缓存

    【Hibernate缓存详解】 在Java开发中,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。其缓存机制是提升系统性能的关键所在。本篇将深入探讨Hibernate的缓存机制,包括一级缓存和二级...

Global site tag (gtag.js) - Google Analytics