• Java Hibernate 二级缓存配置及缓存的统计策略


    • 1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:  
    • <propertyname="hibernate.cache.use_second_level_cache">true</property> 
    •  
    • 2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个  
    •    缓存工具。如下配置指定Hibernate使用EhCache缓存工具。  
    • <propertyname="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property> 
    •  
    • 3、Hibernate在默认情况下并不会对所有实体对象进行缓存,所以,我们需要指定缓存哪些对象,  
    • 在实体对象的映射文件中(相应的<class>标签内部),添加如下配置:  
    • <cacheusage="read-only"/> 
    •  
    • usage="read-only"是“只读”缓存策略。  
    •  
    • 注意,这个<cache>标签只能放在<class>标签的内部,而且必须处在<id>标签的前面!!!  
    • 这个<cache>标签放在哪些<class>标签下面,就说明会多这些类的对象进行缓存  
    •  
    • 4、对于第3步,有一个可选的方案是在hibernate.cfg.xml文件中指定哪些类的对象需要缓存,  
    •    而不需要使用<cache>标签来指定。如:  
    •    在hibernate.cfg.xml中添加如下配置:  
    •    <class-cacheclass="com.bjsxt.hibernate.Classes"usage="read-only"/> 
    •     
    •    注意,这个<class-cache>标签必须放在<mapping>标签的后面!!  

    1、首先设置EhCache,建立配置文件ehcache.xml,默认的位置在class-path,可以放到你的src目录下:

    <?xml version="1.0" encoding="UTF-8"?>
    <ehcache>
     <diskStore path="java.io.tmpdir"/>
      <defaultCache
       maxElementsInMemory="10000" <!-- 缓存最大数目 -->
       eternal="false" <!-- 缓存是否持久 -->
       overflowToDisk="true" <!-- 是否保存到磁盘,当系统当机时-->
       timeToIdleSeconds="300" <!-- 当缓存闲置n秒后销毁 -->
       timeToLiveSeconds="180" <!-- 当缓存存活n秒后销毁-->
       diskPersistent="false"
       diskExpiryThreadIntervalSeconds= "120"/>
    </ehcache>

      2、在Hibernate配置文件中设置:

    <!-- 设置Hibernate的缓存接口类,这个类在Hibernate包中 -->
    <property name="cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
     <!-- 是否使用查询缓存 -->
     <property name="hibernate.cache.use_query_cache">true</property>
      如果使用spring调用Hibernate的sessionFactory的话,这样设置:
      <!--HibernateSession工厂管理 -->
       <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
       <property name="dataSource">
        <ref bean="datasource" />
       </property>
       <property name="hibernateProperties">
       <props>
        <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
        <prop key="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
        <prop key="hibernate.show_sql">true</prop>
        <prop key="hibernate.cache.use_query_cache">true</prop>
        <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
       </props>
     </property>
     <property name="mappingDirectoryLocations">
      <list>
       <value>/WEB-INF/classes/cn/rmic/manager/hibernate/</value>
      </list>
     </property>
    </bean>

      说明一下:如果不设置“查询缓存”,那么hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用findall()、list()、Iterator()、createCriteria()、createQuery()等方法获得的数据结果集的话, 就需要设置
    hibernate.cache.use_query_cache true 才行

      3、在Hbm文件中添加<cache usage="read-only"/>

      4、如果需要“查询缓存”,还需要在使用Query或Criteria()时设置其setCacheable(true);属性

      5、实践出真知,给一段测试程序,如果成功的话第二次查询时不会读取数据库

    package cn.rmic.hibernatesample;
    
    import java.util.List;
    import org.hibernate.CacheMode;
    import org.hibernate.Criteria;
    import org.hibernate.Query;
    import org.hibernate.Session;
    import cn.rmic.hibernatesample.hibernate.HibernateSessionFactory;
    import cn.rmic.manager.po.Resources;
    
    public class testCacheSelectList ...{
    
     /** *//**
     * @param args
     */
     public static void main(String[] args) ...{
      // TODO Auto-generated method stub
    
      Session s=HibernateSessionFactory.getSession();
      Criteria c=s.createCriteria(Resources.class);
      c.setCacheable(true);
      List l=c.list();
      // Query q=s.createQuery("From Resources r")
      // .setCacheable(true) 
      // .setCacheRegion("frontpages") ;
      // List l=q.list();
      Resources resources=(Resources)l.get(0);
      System.out.println("-1-"+resources.getName());
      HibernateSessionFactory.closeSession();
      try ...{
       Thread.sleep(5000);
      } catch (InterruptedException e) ...{
       // TODO Auto-generated catch block
       e.printStackTrace();
      }
      s=HibernateSessionFactory.getSession();
      c=s.createCriteria(Resources.class);
      c.setCacheable(true);
      l=c.list();
      // q=s.createQuery("From Resources r").setCacheable(true) 
      // .setCacheRegion("frontpages");
      // l=q.list();
      resources=(Resources)l.get(0);
      System.out.println("-2-"+resources.getName());
      HibernateSessionFactory.closeSession();
     }
    }

     

    在Hibernate程序中如果配置了二级缓存,想查看一下二级缓存中存放的数据条数,查询时错过的数据条数,缓存命中率等信息,那么该怎么办呢?

            在Hibernate的hibernate.cfg.xml文件中,提供了hibernate.generate_statistics属性,该属性提供了Hibernate应用中操作的统计信息,必须在hibernate.cfg.xml文件中进行配置。该属性在配置文件中的默认值是关闭的,因为它会消耗一些资源,但是它很适合在我们开发过程中调试程序时使用。hibernate.cfg.xml文件中的配置如下:

            <property name="generate_statistics">true</property/>

            这时我们已经将Hibernate的统计信息打开了,接下来我们应该怎样使用它呢?

            在org.hibernate.SessionFactory类中提供了一个得到统计信息的方法,该方法返回一个Statistic类型的数据。之后我们通过Statistics对象取出数据操作时的缓存信息。它提供了取出全部统计信息和取出指定缓存的统计信息,例如:我们就想查看二级缓存中的统计信息,那么可以通过方法指定。例如:我们添加一条数据,该方法是addPet(),将该方法放到main()方法中测试,如下:

            addPet()方法的实现:

    public void addPet(){   // 创建一个Hibernate Configuration类的实例   Configuration config = new Configuration().configure() ;   // 创建SessionFactory对象   SessionFactory sf = config.buildSessionFactory() ;   // 调用调添加方法                                                                                                                                                     PetDaoImpl petImpl = new PetDaoImpl();

      petImpl.add();

      // 创建Statistics对象,并通过SessionFactory对象获得统计信息 Statistics st =  sf.getStatistics();   // 打印全部统计信息  System.out.println(st);   // 打印二级缓存信息   System.out.println(st.getSecondLevelCacheHitCount()); }

             将addPet()方法添加到main()方法中进行测试,将会输出统计信息。

  • 相关阅读:
    P4630-[APIO2018]Duathlon铁人两项【圆方树】
    P4980-[模板]Pólya定理
    bzoj4589-Hard Nim【FWT】
    CF700E-Cool Slogans【SAM,线段树合并,dp】
    sqrt数据结构
    NOIP历年好题
    ACM题解吖
    [ZJOI2010]排列计数
    [CQOI2014]数三角形
    [SHOI2007]书柜的尺寸
  • 原文地址:https://www.cnblogs.com/a284628487/p/2888473.html
Copyright © 2020-2023  润新知