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,如下: