二级缓存配置

来源:互联网 发布:海康网络控制键盘 编辑:程序博客网 时间:2024/05/22 11:35
  1. 二级缓存配置:   
  2.   
  3. 1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:   
  4. <property name="hibernate.cache.use_second_level_cache">true</property>  
  5.   
  6. 2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个   
  7.    缓存工具。如下配置指定Hibernate使用EhCache缓存工具。   
  8. <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>  
  9.   
  10. 3、Hibernate在默认情况下并不会对所有实体对象进行缓存,所以,我们需要指定缓存哪些对象,   
  11. 在实体对象的映射文件中(相应的<class>标签内部),添加如下配置:   
  12. <cache usage="read-only"/>  
  13.   
  14. usage="read-only"是“只读”缓存策略。   
  15.   
  16. 注意,这个<cache>标签只能放在<class>标签的内部,而且必须处在<id>标签的前面!!!   
  17. 这个<cache>标签放在哪些<class>标签下面,就说明会多这些类的对象进行缓存   
  18.   
  19. 4、对于第3步,有一个可选的方案是在hibernate.cfg.xml文件中指定哪些类的对象需要缓存,   
  20.    而不需要使用<cache>标签来指定。如:   
  21.    在hibernate.cfg.xml中添加如下配置:   
  22.    <class-cache class="com.bjsxt.hibernate.Classes" usage="read-only" />  
  23.      
  24.    注意,这个<class-cache>标签必须放在<mapping>标签的后面!!  














  25. 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();
     }
    }