亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Ehcache簡介_動力節點Java學院整理

發布時間:2020-08-21 14:08:42 來源:腳本之家 閱讀:117 作者:chenjumin 欄目:編程語言

使用Spring的AOP進行整合,可以靈活的對方法的返回結果對象進行緩存。

CachingFilter功能可以對HTTP響應的內容進行緩存。

1、主要特性

     1. 快速.
     2. 簡單.
     3. 多種緩存策略
     4. 緩存數據有兩級:內存和磁盤,因此無需擔心容量問題
     5. 緩存數據會在虛擬機重啟的過程中寫入磁盤
     6. 可以通過RMI、可插入API等方式進行分布式緩存
     7. 具有緩存和緩存管理器的偵聽接口
     8. 支持多緩存管理器實例,以及一個實例的多個緩存區域
     9. 提供Hibernate的緩存實現
     10. 等等

2、配置文件介紹(普通緩存) 

<ehcache> 
  <!-- 指定一個文件目錄,當EHCache把數據寫到硬盤上時,將把數據寫到這個文件目錄下 --> 
  <diskStore path="java.io.tmpdir"/> 
 
  <!-- 設定緩存的默認數據過期策略 --> 
  <defaultCache 
      maxElementsInMemory="10000" 
      eternal="false" 
      overflowToDisk="true" 
      timeToIdleSeconds="0" 
      timeToLiveSeconds="0" 
      diskPersistent="false" 
      diskExpiryThreadIntervalSeconds="120"/> 
   
  <!--  
    設定具體的命名緩存的數據過期策略 
 
    cache元素的屬性: 
      name:緩存名稱 
       
      maxElementsInMemory:內存中最大緩存對象數 
       
      maxElementsOnDisk:硬盤中最大緩存對象數,若是0表示無窮大 
       
      eternal:true表示對象永不過期,此時會忽略timeToIdleSeconds和timeToLiveSeconds屬性,默認為false 
       
      overflowToDisk:true表示當內存緩存的對象數目達到了maxElementsInMemory界限后,會把溢出的對象寫到硬盤緩存中。注意:如果緩存的對象要寫入到硬盤中的話,則該對象必須實現了Serializable接口才行。 
       
      diskSpoolBufferSizeMB:磁盤緩存區大小,默認為30MB。每個Cache都應該有自己的一個緩存區。 
       
      diskPersistent:是否緩存虛擬機重啟期數據 
       
      diskExpiryThreadIntervalSeconds:磁盤失效線程運行時間間隔,默認為120秒 
 
      timeToIdleSeconds: 設定允許對象處于空閑狀態的最長時間,以秒為單位。當對象自從最近一次被訪問后,如果處于空閑狀態的時間超過了timeToIdleSeconds屬性值,這個對象就會過期,EHCache將把它從緩存中清空。只有當eternal屬性為false,該屬性才有效。如果該屬性值為0,則表示對象可以無限期地處于空閑狀態 
       
      timeToLiveSeconds:設定對象允許存在于緩存中的最長時間,以秒為單位。當對象自從被存放到緩存中后,如果處于緩存中的時間超過了 timeToLiveSeconds屬性值,這個對象就會過期,EHCache將把它從緩存中清除。只有當eternal屬性為false,該屬性才有效。如果該屬性值為0,則表示對象可以無限期地存在于緩存中。timeToLiveSeconds必須大于timeToIdleSeconds屬性,才有意義 
 
      memoryStoreEvictionPolicy:當達到maxElementsInMemory限制時,Ehcache將會根據指定的策略去清理內存。可選策略有:LRU(最近最少使用,默認策略)、FIFO(先進先出)、LFU(最少訪問次數)。 
  --> 
  <cache name="CACHE1" 
      maxElementsInMemory="1000" 
      eternal="true" 
      overflowToDisk="true"/>  
       
  <cache name="CACHE2" 
    maxElementsInMemory="1000" 
    eternal="false" 
    timeToIdleSeconds="200" 
    timeToLiveSeconds="4000" 
    overflowToDisk="true"/> 
</ehcache> 

3、配置文件介紹(分布式緩存) 

 1)RMI集群模式

A、手工發現

需要指定節點發現模式peerDiscovery值為manual,rmiUrls設置為另一臺服務器的IP、端口和緩存名等信息。

<cacheManagerPeerProviderFactory  
  class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory"  
  properties="peerDiscovery=manual, 
  rmiUrls=//192.168.0.12:4567/bjpowernode_cache|//192.168.0.13:4567/bjpowernode_cache" 
/> 

B、自動發現

需要指定節點發現模式peerDiscovery值為automatic自動,同時組播地址可以指定D類IP地址空間,范圍從 224.0.1.0 到 238.255.255.255 中的任何一個地址。

<cacheManagerPeerProviderFactory 
  class="net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory" 
  properties="peerDiscovery=automatic, multicastGroupAddress=230.0.0.1, 
  multicastGroupPort=4446, timeToLive=32" 
/> 

需要在每個cache屬性中加入

<cacheEventListenerFactory class="net.sf.ehcache.distribution.RMICacheReplicatorFactory"/>
<cache name="demoCache" 
  maxElementsInMemory="10000" 
  eternal="true" 
  overflowToDisk="true"> 
  <cacheEventListenerFactory class="net.sf.ehcache.distribution.RMICacheReplicatorFactory"/> 
</cache>  

4、通過編程方式使用EhCache

//從classes目錄查找ehcache.xml配置文件 
CacheManager cacheManager = CacheManager.getInstance(); 
 
//從classes目錄查找指定名稱的配置文件 
//CacheManager cacheManager = CacheManager.create(getClass().getResource("/ehcache.xml")); 
 
//根據配置文件獲得Cache實例 
Cache cache = cacheManager.getCache("CACHE1"); 
 
//清空Cache中的所有元素 
cache.removeAll(); 
 
//往Cache中添加元素 
cache.put(new Element("s1", "11111")); 
cache.put(new Element("s2", "22222")); 
cache.put(new Element("s3", "33333")); 
 
//從Cache中取得元素 
Element e = cache.get("s3"); 
System.out.println(e.getValue()); 
 
//卸載緩存管理器 
cacheManager.shutdown(); 

5、頁面緩存

在web.xml文件中配置過濾器。此處對test_tag.jsp頁面進行緩存。

<filter>  
  <filter-name>testPageCachingFilter</filter-name>  
  <filter-class>net.sf.ehcache.constructs.web.filter.SimplePageCachingFilter</filter-class>  
</filter> 
<filter-mapping>  
  <filter-name>testPageCachingFilter</filter-name>  
  <url-pattern>/test_tag.jsp</url-pattern> 
</filter-mapping> 

在ehcache.xml文件中配置Cache節點。注意:cache的name屬性必需為SimplePageCachingFilter。

<cache name="SimplePageCachingFilter"  
  maxElementsInMemory="10"  
  overflowToDisk="true"  
  eternal="false"  
  timeToIdleSeconds="100"  
  timeToLiveSeconds="100" 
  memoryStoreEvictionPolicy="LFU" /> 

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

德庆县| 汾西县| 永昌县| 江安县| 六枝特区| 新郑市| 泸定县| 伊金霍洛旗| 简阳市| 安远县| 黑龙江省| 张家川| 雅安市| 武夷山市| 苏州市| 来凤县| 中江县| 江城| 鞍山市| 荣成市| 诸城市| 平远县| 自治县| 措勤县| 开阳县| 紫金县| 永泰县| 娱乐| 嘉定区| 太保市| 万山特区| 昭苏县| 呼伦贝尔市| 明星| 绥中县| 浦县| 广德县| 彰化市| 漳州市| 镇沅| 宜兰市|