`

EhCache使用详细介绍(转)

 
阅读更多
EhCache使用详细介绍(转)
Ehcache中不仅可以用配置文件来配置缓存,而在代码中也可以实现同样的功能。
CacheManager singletonManager = CacheManager.create();
Cache memoryOnlyCache = new Cache(“testCache”, 50000, false, false, 8, 2);
Cache test = singletonManager.getCache(“testCache”);
删除只需要调用singletonManager.removeCache(“testCache”);
Shotdown CacheManager
在使用完Ehcache后,必须要shutdown缓存。Ehcache中有自己的关闭机制,不过最好在你的代码中显示调用CacheManager.getInstance().shutdown();
1.EhCache是什么
    EhCache是Hibernate的二级缓存技术之一,可以把查询出来的数据存储在内存或者磁盘,节省下次同样查询语句再次查询数据库,大幅减轻数据库压力;

2.EhCache的使用注意点
    当用Hibernate的方式修改表数据(save,update,delete等等),这时EhCache会自动把缓存中关于此表的所有缓存全部删除掉(这样能达到同步)。但对于数据经常修改的表来说,可能就失去缓存的意义了(不能减轻数据库压力);

3.EhCache使用的场合
    3.1比较少更新表数据
        EhCache一般要使用在比较少执行write操作的表(包括update,insert,delete等)[Hibernate的二级缓存也都是这样];
    3.2对并发要求不是很严格的情况
        两台机子中的缓存是不能实时同步的;

4.在项目做的实现
    4.1在工程的src目录下添加ehcache.xml文件,内容如下:
        <?xml version="1.0" encoding="UTF-8"?>
        <ehcache>    
            <diskStore path="java.io.tmpdir" />
          <defaultCache maxElementsInMemory="5"<!--缓存可以存储的总记录量-->
            eternal="false"<!--缓存是否永远不销毁-->
            overflowToDisk="true"<!--当缓存中的数据达到最大值时,是否把缓存数据写入磁盘-->
            timeToIdleSeconds="15"<!--当缓存闲置时间超过该值,则缓存自动销毁-->
                timeToLiveSeconds="120"<!--缓存创建之后,到达该缓存自动销毁-->
          />
        </ehcache>
    4.2在Hibernate.cfg.xml中的mapping标签上面加以下内容:
        <property name="show_sql">true</property>
        <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
        <property name="hibernate.cache.use_query_cache">true</property>
    4.3在要缓存的bean的hbm.xml文件中的class标签下加入以下内容:
       <cache usage="read-only" /><!--也可读写-->
    4.4创建DAO,内容如下:
        Session s = HibernateSessionFactory.getSession();
        Criteria c = s.createCriteria(Xyz.class);
        c.setCacheable(true);//这句必须要有
        System.out.println("第一次读取");
        List l = c.list();
        System.out.println(l.size());
        HibernateSessionFactory.closeSession();

        s = HibernateSessionFactory.getSession();
        c = s.createCriteria(Xyz.class);
        c.setCacheable(true);//这句必须要有
        System.out.println("第二次读取");
        l = c.list();
        System.out.println(l.size());
        HibernateSessionFactory.closeSession();
   4.5这时你会看到打印出来的信息为(表示第二次并没有去读库):
        第一次读取
        Hibernate: *******
        13
        第二次读取
        13
配置Spring+hibernate使用ehcache作为second-level cache
大量数据流动是web应用性能问题常见的原因,而缓存被广泛的用于优化数据库应用。cache被设计为通过保存从数据库里load的数据来减少应用和数据库之间的数据流动。数据库访问只有当检索的数据不在cache里可用时才必要。hibernate可以用两种不同的对象缓存:first-level cache 和 second-level cache。first-level cache和Session对象关联,而second-level cache是和Session Factory对象关联。
        缺省地,hibernate已经使用基于每个事务的first-level cache。 Hibernate用first-level cache主要是减少在一个事务内的sql查询数量。例如,如果一个对象在同一个事务内被修改多次,hibernate将只生成一个包括所有修改的 UPDATE SQL语句。为了减少数据流动,second-level cache在Session Factory级的不同事务之间保持load的对象,这些对象对整个应用可用,不只是对当前用户正在运行的查询。这样,每次查询将返回已经load在缓存里的对象,避免一个或更多潜在的数据库事务。
下载ehcache,hibernate3.2必须要ehcache1.2以上才能支持。可以修改log4j配置文件log4j.logger.net.sf.hibernate.cache=debug查看日志
1.在类路径上ehcache.xml:
<ehcache>
     <!-- Sets the path to the directory where cache .data files are created.
          If the path is a Java System Property it is replaced by
          its value in the running VM.
          The following properties are translated:
          user.home - User's home directory
          user.dir - User's current working directory
          java.io.tmpdir - Default temp file path -->
     <diskStore path="java.io.tmpdir"/>

     <!--Default Cache configuration. These will applied to caches programmatically created through
         the CacheManager.
         The following attributes are required:
         maxElementsInMemory             - Sets the maximum number of objects that will be created in memory
         eternal                         - Sets whether elements are eternal. If eternal,   timeouts are ignored and the
                                          element is never expired.
         overflowToDisk                  - Sets whether elements can overflow to disk when the in-memory cache
                                          has reached the maxInMemory limit.
         The following attributes are optional:
         timeToIdleSeconds               - Sets the time to idle for an element before it expires.
                                          i.e. The maximum amount of time between accesses before an element expires
                                          Is only used if the element is not eternal.
                                          Optional attribute. A value of 0 means that an Element can idle for infinity.
                                          The default value is 0.
         timeToLiveSeconds               - Sets the time to live for an element before it expires.
                                          i.e. The maximum time between creation time and when an element expires.
                                          Is only used if the element is not eternal.
                                          Optional attribute. A value of 0 means that and Element can live for infinity.
                                          The default value is 0.
         diskPersistent                  - Whether the disk store persists between restarts of the Virtual Machine.
                                          The default value is false.
         diskExpiryThreadIntervalSeconds- The number of seconds between runs of the disk expiry thread. The default value
                                          is 120 seconds.
         -->
     <defaultCache
         maxElementsInMemory="10000"
         eternal="false"
         overflowToDisk="true"
         timeToIdleSeconds="120"
         timeToLiveSeconds="120"
         diskPersistent="false"
         diskExpiryThreadIntervalSeconds="120"/>
       
     <!-- See http://ehcache.sourceforge.net/documentation/#mozTocId258426 for how to configure caching for your objects -->
</ehcache>
2.applicationContext-hibernate.xml里Hibernate SessionFactory配置:
     <!-- Hibernate SessionFactory -->
     <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
         <property name="dataSource" ref="dataSource"/>
         <property name="configLocation"><value>classpath:hibernate.cfg.xml</value></property>
         <!-- The property below is commented out b/c it doesn't work when run via
              Ant in Eclipse.   It works fine for individual JUnit tests and in IDEA ??
         <property name="mappingJarLocations">
             <list><value>file:dist/appfuse-dao.jar</value></list>
         </property>
         -->
         <property name="hibernateProperties">
             <props>
                 <prop key="hibernate.dialect">@HIBERNATE-DIALECT@</prop>
                 <!--<prop key="hibernate.show_sql">true</prop>-->
                 <prop key="hibernate.max_fetch_depth">3</prop>
                 <prop key="hibernate.hibernate.use_outer_join">true</prop>
                 <prop key="hibernate.jdbc.batch_size">10</prop>
                 <prop key="hibernate.cache.use_query_cache">true</prop>
                 <prop key="hibernate.cache.use_second_level_cache">true</prop>
                 <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
                 <!--
                 <prop key="hibernate.use_sql_comments">false</prop>
                 -->
                 <!-- Create/update the database tables automatically when the JVM starts up
                 <prop key="hibernate.hbm2ddl.auto">update</prop> -->
                 <!-- Turn batching off for better error messages under PostgreSQL
                 <prop key="hibernate.jdbc.batch_size">0</prop> -->
             </props>
         </property>
         <property name="entityInterceptor">
            <ref local="auditLogInterceptor"/>
         </property>
     </bean>
说明:如果不设置“查询缓存”,那么hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用findall()、 list()、Iterator()、createCriteria()、createQuery()等方法获得的数据结果集的话,就需要设置 hibernate.cache.use_query_cache true 才行
3.model类里采用Xdoclet生成*.hbm.xml里的cache xml标签,即<cache usage="read-only"/>
/**
* @hibernate.class table="WF_WORKITEM_HIS"
* @hibernate.cache usage="read-write"
*
*/
4.对于"query cache",需要在程序里编码:
         getHibernateTemplate().setCacheQueries(true);
         return getHibernateTemplate().find(hql);
使用spring和hibernate配置ehcache和query cache 1、applicationContext.xml
<prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
<prop key="hibernate.cache.use_query_cache">true</prop>
这两句加到hibernateProperties中
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory">
   <ref bean="sessionFactory" />
</property>
<property name="cacheQueries">
   <value>true</value>
</property>
</bean>
添加此bean到applicationcontext.xml中。在各个DAO的bean中,更改如下
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
改为
<property name="hibernateTemplate">
<ref bean="hibernateTemplate" />
</property>
2、ehcache.xml文件放在classes根目录即可
3、pojo与ehcache.xml的配置关系
以com.ce.ceblog.pojos.CeblogJournal为例子
在CeblogJournal.hbm.xml中配置:
<class name="CeblogJournal" table="CEBLOG_JOURNAL" lazy="false">
<cache usage="read-write" region="ehcache.xml中的name的属性值"/>
注意:这一句需要紧跟在class标签下面,其他位置无效。
Ehcache.xml文件主体如下
<defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="1" timeToLiveSeconds="1" overflowToDisk="true" />
<cache name="com.ce.ceblog.pojos.CeblogJournal" maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="300" timeToLiveSeconds="600" overflowToDisk="true" />
hbm文件查找cache方法名的策略:如果不指定hbm文件中的region="ehcache.xml中的name的属性值",则使用name名为 com.ce.ceblog.pojos.CeblogJournal的cache,如果不存在与类名匹配的cache名称,则用 defaultCache。
如果CeblogJournal包含set集合,则需要另行指定其cache
例如CeblogJournal包含ceblogReplySet集合,则需要
添加如下配置到ehcache.xml中
<cache name="com.ce.ceblog.pojos.CeblogJournal.ceblogReplySet"
maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="300"
timeToLiveSeconds="600" overflowToDisk="true" />
另,针对查询缓存的配置如下:
<cache name="org.hibernate.cache.UpdateTimestampsCache"
maxElementsInMemory="5000"
eternal="true"
overflowToDisk="true"/>
<cache name="org.hibernate.cache.StandardQueryCache"
maxElementsInMemory="10000"
eternal="false"
timeToLiveSeconds="120"
overflowToDisk="true"/>
4、选择缓存策略依据:
<cache usage="transactional|read-write|nonstrict-read-write|read-only" />
ehcache不支持transactional,其他三种可以支持。
read- only:无需修改, 那么就可以对其进行只读 缓存,注意,在此策略下,如果直接修改数据库,即使能够看到前台显示效果,但是将对象修改至cache中会报error,cache不会发生作用。另:删 除记录会报错,因为不能在read-only模式的对象从cache中删除。
read-write:需要更新数据,那么使用读/写缓存 比较合适,前提:数据库不可以为serializable transaction isolation level(序列化事务隔离级别)
nonstrict-read-write:只偶尔需要更新数据(也就是说,两个事务同时更新同一记录的情况很不常见),也不需要十分严格的事务隔离,那么比较适合使用非严格读/写缓存策略。
5、调试时候使用log4j的log4j.logger.org.hibernate.cache=debug,更方便看到ehcache的操作过程,主要用于调试过程,实际应用发布时候,请注释掉,以免影响性能。
6、 使用ehcache,打印sql语句是正常的,因为query cache设置为true将会创建两个缓存区域:一个用于保存查询结果集 (org.hibernate.cache.StandardQueryCache);另一个则用于保存最近查询的一系列表的时间戳(org.hibernate.cache.UpdateTimestampsCache)。请注意:在查询缓存中,它并不缓存结果集中所包含的实体的确切状态;它只缓存这些实体的标识符属性的值、以及各值类型的结果。需要将打印sql语句与最近的cache内容相比较,将不同之处修改到cache中,所以查询缓存通常会和二级缓存一起使用。
分享到:
评论

相关推荐

    springmvc4+spring4+hibernate5.1.3+二级缓存ehcache+fastjson配置

    以下是这些技术的详细介绍: 1. **SpringMVC**: SpringMVC是Spring框架的一部分,专门用于构建Web应用程序的模型-视图-控制器(MVC)架构。它简化了处理HTTP请求、业务逻辑处理和视图渲染的过程。SpringMVC通过...

    hessian-3.0.20.jar,ehcache-1.2.3.jar,commons-codec-1.3.jar

    这些JAR文件是Java开发中常用的库,它们包含了不同功能的API和服务,下面将详细介绍这三个组件及其在IT领域的应用。 1. **Hessian-3.0.20.jar**: Hessian是一个轻量级的二进制Web服务协议,由Caucho Technology开发...

    SpringSide4 参考手册

    接着,文档详细介绍了如何在SpringSide中使用各种数据访问技术,包括Spring Data JPA、MyBatis以及原生JPA。这些部分讲述了如何进行动态组合查询条件、使用Hibernate二级缓存、以及如何配置数据源和事务管理。 为了...

    SSH整合需要的JAR包详细介绍

    - **ehcache.jar**:EHCache缓存库,用于存储和管理缓存数据,提高应用性能。 - **antlr.jar**:语言转换工具,帮助Hibernate将HQL(Hibernate Query Language)转换为SQL语句。 - **jta.jar**:Java Transaction...

    j2ee框架笔记详细介绍j2ee的框架结构

    - **缓存策略**:对于频繁访问的数据,可以采用缓存技术,如 Ehcache 或 Redis,减少对数据库的压力。 - **负载均衡**:在大型应用中,考虑使用负载均衡器分配请求,提高系统整体性能。 - **事务管理**:在处理...

    jar包介绍大全

    本文旨在为初学者详细介绍一些常用的jar包及其应用场景,帮助大家更好地理解和掌握这些重要的资源。 #### JTA (jta.jar) JTA (Java Transaction API) 是一个用于管理事务的标准接口,它定义了应用程序如何与事务...

    介绍J2EE常用Jar包的含义.doc

    本文档将详细介绍一些常见的J2EE Jar包及其作用。 #### 二、Jar包详细介绍 1. **activation.jar** - **用途**: 与JavaMail相关的库,主要负责邮件的数据源和类型管理等。通常与`mail.jar`一起使用。 - **应用...

    尚硅谷Mybatis视频教程51-60

    54集介绍了二级缓存的基本概念,为后续的详细讲解奠定了基础。接着55、56集详细讲述了二级缓存的使用和配置细节,包括如何开启二级缓存,以及相关设置和属性的调整。 57集通过缓存原理图示,直观地展示了Mybatis...

    hibernate-3.6.7.final-manual-zh-cn

    4. **会话和事务**:详细介绍了Hibernate的Session接口,它是数据库会话的代理,负责保存、检索和删除对象。同时,手册也会讨论事务管理,包括JTA和JTASession接口的使用。 5. **查询语言**:HQL(Hibernate Query ...

    hibernate实战第二版.pdf

    这本书针对初学者和有经验的开发者,详细介绍了如何使用Hibernate进行数据库操作,提升开发效率。 在ORM领域,Hibernate提供了强大的数据持久化解决方案,使得开发者可以使用面向对象的方式来处理数据库事务,而...

    hibernate3使用手册

    以上是对Hibernate3的一些基础知识点的介绍,通过深入学习《Hibernate3使用手册》中的内容,开发者可以更好地掌握这个强大的ORM工具,从而提升Java应用的数据处理效率和灵活性。对于《hibernate3[1].2参考.pdf》和...

    WADE开发文档

    该文档详细介绍了WADE开发框架的基本功能、开发步骤、配置文件的编写方法等内容。 基本功能 WADE开发框架的基本功能包括新建项目功能、开发改造功能等。 新建项目功能 新建项目功能是WADE开发框架的基本功能之一...

    demo工程列表说明1

    5. **Ehcache缓存**:cachedemo展示了Ehcache的使用,Ehcache是Java的一个流行缓存解决方案,用于提高应用程序性能。 6. **CDI(Contexts and Dependency Injection)**:cdidemo解释了如何使用CDI(上下文和依赖...

    关于Hibernate框架

    Chapter06会详细介绍如何使用Hibernate进行这些操作,如Session对象的使用,Transaction的管理,以及对象的状态转换。 4. HQL(Hibernate Query Language):这是Hibernate提供的面向对象的查询语言,类似于SQL但...

    夏昕-Hibernate 开发指南.pdf

    本书由夏昕撰写,详细介绍了Hibernate的核心概念、配置、使用方法以及最佳实践。 1. **Hibernate简介**:Hibernate是一种开源的ORM框架,通过将Java类与数据库表进行映射,使得开发者可以使用面向对象的方式来操作...

    Spring Boot 学习笔记完整教程.pdf

    文档《Spring Boot 学习笔记完整教程.pdf》涵盖了多个知识点,详细介绍了Spring Boot的基本使用方法以及一些高级功能的实现。以下是根据文档内容整理的知识点: 1. Spring Boot入门: Spring Boot让开发者能够通过...

    Hibernate程序高手秘笈.part10-11.rar

    1. **二级缓存**:在这一部分,作者会详细讲解如何配置和使用Hibernate的二级缓存,包括EHCache和Infinispan,以及它们在提高应用程序性能方面的作用。 2. **查询缓存**:查询缓存可以存储查询结果,避免重复执行...

    jfinal-2.2-manual.pdf参考手册

    ### JFinal 2.2 参考手册知识点详解 #### 一、极速体验:Model与Bean合体 **1.1 极速体验Generator** ...以上是JFinal 2.2参考手册中的主要知识点详细介绍,希望能够帮助您更好地理解和使用JFinal框架。

    hibernate v3.12中文参考手册

    手册会介绍如何定义实体类,使用注解或XML文件来进行映射,以及如何处理生命周期方法(如@PrePersist、@PostLoad等)。 4. **会话(Session)**:会话是Hibernate与数据库交互的主要接口,用于执行查询、保存、更新...

Global site tag (gtag.js) - Google Analytics