1. 程式人生 > >hibernate二級快取 Ehcache配置詳解

hibernate二級快取 Ehcache配置詳解

一、hibernate快取簡介

一級快取(session):內部快取 事務範圍:快取只能被當前事務訪問。快取的生命週期依賴於事務的生命週期,當事務結束時,快取也就結束生命週期 二級快取(sessionFactory): 快取被應用範圍內的所有事務共享。 這些事務有可能是併發訪問快取,因此必須對快取進行更新。快取的生命週期依賴於應用的生命週期,應用結束時, 快取也就結束了生命週期,二級快取存在於應用範圍。叢集範圍:在叢集環境中,快取被一個機器或者多個機器的程序共享。快取中的資料被複制到叢集環境中的每個程序節點,程序間通過遠端通訊來保證快取中的資料的一致性, 快取中的資料通常採用物件的鬆散資料形式,二級快取也存在與應用範圍。
注意:對大多數應用來說,應該慎重地考慮是否需要使用叢集範圍的快取,再加上叢集範圍還有資料同步的問題,所以應當慎用。多種範圍的快取處理過程持久化層可以提供多種範圍的快取。如果在事務範圍的快取中沒有查到相應的資料,還可以到應用範圍或叢集範圍的快取內查詢,如果還是沒有查到,那麼只有到資料庫中查詢了。 使用二級快取的原則: ◆資料不會被第三方修改 ◆同一資料系統經常引用 ◆資料大小在可接受範圍之內 ◆關鍵資料或不會被併發更新的資料

二、EhCache簡介

EHCache 是一個非常輕量級的快取實現,是一個純Java的程序內快取框架,而且從1.2 之後就支援了叢集,是Hibernate中預設的CacheProvider。

具有快速、精幹等特點,Ehcache可以直接使用。

也可以和Hibernate物件/關係框架結合使用。可以將物件、資料、jsp、Servlet進行快取。

Cache 儲存方式 :記憶體或磁碟。

三、配置

1、首先到官網下載ehcache-core.jar、ehcache-web.jar最新版本,然後加入所在工程的lib中

2、在hibernate的相關配置中新增如下:

               <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.cache.provider_configuration_file_resource_path">/ehcache.xml</prop>

3、需要在對映檔案*.hbm.xml中<class name="" table="" > 節點下新增如下:

     <!-- 快取策略 -->
     <cache usage="read-write"/>

4、在src根目錄下加入ehcache.xml檔案,具體內容如下:

 <?xml version="1.0" encoding="UTF-8"?>
<ehcache>

 <!-- 資料快取存放目錄 -->
  <diskStore path="/jcms_cache_data/ehcache"/>
  <!--
   頁面快取
   三種快取演算法:LRU-最近最少使用、LFU-較少頻率使用和FIFO-先進先出。

  引數詳解:

   simplePageCachingFilter 快取的名稱
   maxElementsInMemory 快取中元素的最大數量
   maxElementsOnDisk 持久化到硬碟的快取元素的最大數量
   eternal="false"  如果為true,表示物件永遠不會過期,此時會忽略timeToIdleSeconds和timeToLiveSeconds屬性,預設為false;
   overflowToDisk="true" 當快取中元素數量超過限制時,將這些元素持久化到硬碟,為false時,設定沒意義。
   timeToIdleSeconds 多長時間不訪問快取,那麼就清除該快取
   timeToLiveSeconds 快取的存活時間
   -->
  <cache name="SimplePageCachingFilter" 
         maxElementsInMemory="10000" 
         maxElementsOnDisk="1000" 
         eternal="false" 
         overflowToDisk="true" 
         timeToIdleSeconds="5" 
         timeToLiveSeconds="30" 
         memoryStoreEvictionPolicy="LFU"/>
  
  <!-- Ehcache 物件、資料快取用以下配置 -->
  <defaultCache  maxElementsInMemory="10000"
        eternal="false"
        timeToIdleSeconds="120"
        timeToLiveSeconds="120"
        overflowToDisk="true"
        diskSpoolBufferSizeMB="30"
        maxElementsOnDisk="10000000"
        diskPersistent="false"
        diskExpiryThreadIntervalSeconds="120"/>
</ehcache>

5、web.xml中加入以下配置:

<!-- Ehcache頁面快取配置 -->
   <filter> 
     <filter-name>PageCacheFilter</filter-name> 
        <filter-class>net.cnki.tpi.cms.util.PageCacheFilter</filter-class> 
        <!-- 初始化引數為無需快取的URL,多個以逗號分隔 -->
        <init-param>
         <param-name>notCacheUrlList</param-name>
         <param-value>/jcms/pcons/getUserManager.action</param-value>
        </init-param>
   </filter> 
  <filter-mapping> 
     <filter-name>PageCacheFilter</filter-name> 
     <url-pattern>/*</url-pattern> 
  </filter-mapping>

5、寫一個Filter,繼承SimplePageCachingFilter,如下: