緩存利器之Ehcache

 

 

EhCache 是一個純Java的進程內緩存框架,具備快速、精幹等特色。是一種普遍使用的開源Java分佈式緩存。主要面向通用緩存,Java EE和輕量級容器。另外Spring 提供了對緩存功能的抽象:即容許綁定不一樣的緩存解決方案(如Ehcache),但自己不直接提供緩存功能的實現。ehcache是一個用Java實現的使用簡單,高速,實現線程安全的緩存管理類庫,ehcache提供了用內存,磁盤文件存儲,以及分佈式存儲方式等多種靈活的cache管理方案。同時ehcache做爲開放源代碼項目,採用限制比較寬鬆的Apache License V2.0做爲受權方式,被普遍地用於Hibernate,  Spring,Cocoon等其餘開源系統。它支持註解方式使用緩存,很是方便。web

1.2 Ehcache的特色編程

(1)快速簡單,具備多種緩存策略緩存

(2)緩存數據有兩級爲內存和磁盤,緩存數據會在虛擬機重啓的過程當中寫入磁盤安全

(3)能夠經過RMI、可插入API等方式進行分佈式緩存ruby

(4)具備緩存和緩存管理器的偵聽接口app

(5)支持多緩存管理器實例,以及一個實例的多個緩存區域。並提供Hibernate的緩存實現框架

1.3 Ehcache的類層次模型:jvm

Ehcache的類層次模型主要爲三層,最上層的是CacheManager,他是操做Ehcache的入口。咱們能夠經過CacheManager.getInstance()得到一個單個的CacheManager,或者經過CacheManager的構造函數建立一個新的CacheManager。每一個CacheManager都管理着多個Cache。而每一個Cache都以一種類Hash的方式,關聯着多個Elemenat。而Element則是咱們用於存放要緩存內容的地方。事件處理:能夠爲CacheManager添加事件監聽,當對CacheManager增刪Cache時,事件處理器將會獲得通知。要配置事件處理,須要經過ehcache的配置文件來完成。
能夠爲Cache添加事件監聽,當對Cache增刪Element時,事件處理器將會獲得通知。要配置事件處理,須要經過ehcache的配置文件來完成。socket

1.4 ehcache的刷新策略
ehcache的刷新策略是當緩存在放入的時候記錄一個放入時間,它是用Lazy Evict的方式,在取的時候同設置的TTL比較分佈式

1.5 ehcache緩存的3種清空策略:
1 FIFO,先進先出
2 LFU,最少被使用,緩存的元素有一個hit屬性,hit值最小的將會被清出緩存。
3 LRU,最近最少使用的,緩存的元素有一個時間戳,當緩存容量滿了,而又須要騰出地方來緩存新的元素的時候,那麼現有緩存元素中時間戳離當前時間最遠的元素將被清出緩存。

1.6 ehcache參數配置:
maxInMemory - 設定內存中建立對象的最大值。
eternal - 設置元素(譯註:內存中對象)是否永久駐留。若是是,將忽略超時限制且元素永不消亡。
timeToIdleSeconds - 設置某個元素消亡前的停頓時間。也就是在一個元素消亡以前,兩次訪問時間的最大時間間隔值。這隻能在元素不是永久駐留時有效(譯註:若是對象永恆不滅,則設置該屬性也無用)。
若是該值是 0 就意味着元素能夠停頓無窮長的時間。
timeToLiveSeconds - 爲元素設置消亡前的生存時間。也就是一個元素從構建到消亡的最大時間間隔值。這隻能在元素不是永久駐留時有效。
overflowToDisk  - 設置當內存中緩存達到maxInMemory 限制時元素是否可寫到磁盤上。

1.7 Ehcache結構圖以下:

1.8 Ehcache詳細結構圖以下:

1.9 Ehcache的加載模塊列表,他們都是獨立的庫,每一個都爲Ehcache添加新的功能,能夠在此下載 :

  • ehcache-core:API,標準緩存引擎,RMI複製和Hibernate支持
  • ehcache:分佈式Ehcache,包括Ehcache的核心和Terracotta的庫
  • ehcache-monitor:企業級監控和管理
  • ehcache-web:爲Java Servlet Container提供緩存、gzip壓縮支持的filters
  • ehcache-jcache:JSR107 JCACHE的實現
  • ehcache-jgroupsreplication:使用JGroup的複製
  • ehcache-jmsreplication:使用JMS的複製
  • ehcache-openjpa:OpenJPA插件
  • ehcache-server:war內部署或者單獨部署的RESTful cache server
  • ehcache-unlockedreadsview:容許Terracotta cache的無鎖讀
  • ehcache-debugger:記錄RMI分佈式調用事件
  • Ehcache for Ruby:Jruby and Rails支持

2.0 Ehcache配置:

ehcache 的配置能夠經過在 XML文件中聲明,或者經過構造函數中指定參數進行程序控制。

兩種方法都能很好的支持。不過將緩存的配置和實際代碼分離開來更好一些,這有如下幾個好處:

便於在一個地方保存全部的配置信息
緩存使用內存或磁盤空間須要仔細調整和規劃,你能夠在一個配置文件中獲取全部信息。固然你也能夠都在代碼中搞定,但檢查起來就沒那麼方便。

便於在部署時修改緩存的配置
配置錯誤便於在啓動時被發現,以避免在運行時才暴露出錯誤
若是存在一個缺省配置,那麼它老是會被裝載並生效
雖然缺省配置不是必需的,但若是沒有加載缺省配置,以編程方式建立命名cance(created by name) 就會產生錯誤。

動態修改緩存配置
緩存服務啓動以後,其配置通常不能再改變。但從 ehcache2.0以後,特定的緩存配置參數能夠在運行時動態修改。在當前版本的ehcache,中包含如下幾個參數。

timeToLive 
一個被緩存的對象(Element)保存在緩存中的最大秒數,不管其是否被使用。超過這個時間限制,該對象將沒法從緩存中獲取。默認值是0,表示沒有限制。
timeToIdle 
一個被緩存的對象(Element)保存在緩存中未被訪問的最大秒數。超過這個時間限制,該對象將沒法從緩存中獲取。默認值是0,表示沒有限制。
本地緩存參數 maxEntriesLocalHeap, maxBytesLocalHeap, maxBytesLocalOffHeap, maxEntriesLocalDisk, maxBytesLocalDisk.
memory-store eviction policy (內存驅逐策略)
CacheEventListeners 能夠動態增或刪除
注意Cache 的 "eternal" (永恆)屬性,若是設置爲true,重置 "timeToLive" 和 timeToIdle" 就都沒用了,任何對象都不會過時。

下面的例子演示如何動態修改使用中的緩存。

Cache cache = manager.getCache("sampleCache");

CacheConfiguration config = cache.getCacheConfiguration();

config.setTimeToIdleSeconds(60);

config.setTimeToLiveSeconds(120);

config.setmaxEntriesLocalHeap(10000);

config.setmaxEntriesLocalDisk(1000000);

緩存參數也能夠被凍結,防止修改:

Cache cache = manager.getCache("sampleCache");

cache.disableDynamicFeatures();

在 ehcache.xml中,將<ehcache>的dynamicConfig 屬性設置爲"false", 能夠禁止動態修改緩存參數

動態修改分佈式緩存配置
和獨立緩存同樣,操縱分佈式緩存的配置也須要經過cache.getCacheConfiguration()方法得到 CacheConfiguration 對象,經過它的一系列 set 方法進行修改。

下表提供瞭如何動態修改一個Terracotta 集羣的公共配置選項的一些信息。表頭的"Scope"字段表示配置的變動可以在哪裏生效,能夠是如下幾個值。

Client – The Terracotta client where the CacheManager runs.
TSA – The Terracotta Server Array for the cluster.
BOTH – Both the client and the TSA.
注意 "Both" 是分佈式含義,也就是說對全部客戶端都會生效

2.1 Ehcache 和 Redis 比較以下

 

  Ehcache Redis
存取速度 Ehcache直接在jvm虛擬機中緩存,速度快,效率高 Redis是經過socket訪問到緩存服務,效率比ecache低
集羣和分佈式 Ehcache有緩存共享方案,不過是經過RMI或者Jgroup多播方式進行廣播緩存通知更新,緩存共享複雜,維護不方便;簡單的共享能夠,可是涉及到緩存恢復,大數據緩存,則不合適。 Redis有成熟的分佈式解決方案。適合大規模分佈式集羣部署。
操做複雜度 Ehcache提供的接口很是簡單明瞭,從Ehcache的搭建到運用運行僅僅須要的是你寶貴的幾分鐘。其實不少開發者都不知道本身用在用Ehcache,Ehcache被普遍的運用於其餘的開源項目。好比:Hibernate 至少須要安裝服務端和客戶端才能使用。操做略比Ehcache複雜一些。

2019-06-2500:13:06

相關文章
相關標籤/搜索