ehcache的三級緩存-創(chuàng)新互聯(lián)

開發(fā)架構中,經常把ehcache+redis兩集緩存來做配合。。通常ehcache+redis+mysql 來作為三層存儲架構,最后到數(shù)據(jù)庫,然后db----->redis ---->ehcache 來供程序查詢使用。。
而ehcache本身也支持3級緩存 “堆內內存、堆外內存、磁盤存儲”
作為本地緩存框架, Ehcache支持多層緩存模式,常用的有三種數(shù)據(jù)存儲介質:

1堆內
直接在JVM堆中存儲JAVA對象,優(yōu)點是速度快;缺點是會增加GC的頻次和GC時間。

創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務領域包括:做網站、成都網站建設、企業(yè)官網、英文網站、手機端網站、網站推廣等服務,滿足客戶于互聯(lián)網時代的保亭黎族網站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網解決方案。努力成為您成熟可靠的網絡建設合作伙伴!

2堆外
在堆外內存中存儲序列化的JAVA對象,優(yōu)點是不會增加GC;缺點是存取速度較慢,需要額外的時間處理序列化和反序列化。

3 磁盤
緩存數(shù)據(jù)到磁盤,優(yōu)點是掉電不會丟失數(shù)據(jù),可用空間更大;缺點是存取速度比堆外慢很多。

ehcache的三級緩存

4三種結構一起使用,結構如上圖。

5時序圖

在Ehcache的多層緩存結構中,最底層被稱為Authoritative Tier,其余的緩存層被稱為Caching Tier。Authoritative Tier層數(shù)據(jù)是最全的,其余層的數(shù)據(jù)都是該層的數(shù)據(jù)子集,只是臨時存儲數(shù)據(jù)。

比如,堆內+堆外模式中,堆外為Authoritative Tier。堆內+堆外+磁盤模式中,磁盤為Authoritative Tier。

ehcache的三級緩存

ehcache的三級緩存

6 序列化

堆外和磁盤存儲時,必須先將對象序列化為java.nio.ByteBuffer,Ehcache允許用戶按下面的代碼傳入自定義的序列化類。

7 轉一個demo

import java.io.File;
import org.ehcache.Cache;
import org.ehcache.PersistentCacheManager;
import org.ehcache.UserManagedCache;
import org.ehcache.config.builders.CacheConfigurationBuilder;
import org.ehcache.config.builders.CacheManagerBuilder;
import org.ehcache.config.builders.ResourcePoolsBuilder;
import org.ehcache.config.builders.UserManagedCacheBuilder;
import org.ehcache.config.units.EntryUnit;
import org.ehcache.config.units.MemoryUnit;

public class Main {

public static void main(String[] args) {

    PersistentCacheManager persistentCacheManager = CacheManagerBuilder.newCacheManagerBuilder()
    .with(CacheManagerBuilder.persistence(getStoragePath() + File.separator + "myData")) 
    .withCache("threeTieredCache",
        CacheConfigurationBuilder.newCacheConfigurationBuilder(Integer.class, String.class,
            ResourcePoolsBuilder.newResourcePoolsBuilder()
                .heap(10, EntryUnit.ENTRIES)  //堆
                .offheap(1, MemoryUnit.MB)    //堆外
                .disk(20, MemoryUnit.GB)      //磁盤
            )
    ).build(true);

    Cache<Integer, String> threeTieredCache = persistentCacheManager.getCache("threeTieredCache", Integer.class, String.class);

    //讀
    for (int i=0;i<=20000;i++){
        threeTieredCache.put(i, "$"+i);
    }

    //寫
    for (int i=0;i<=200000;i++){
        String value = threeTieredCache.get(i);
        System.out.println("get at "+i+":"+value);
    }

    persistentCacheManager.close();
}

private static String getStoragePath() {
    // TODO Auto-generated method stub
    return "d:";
}

}

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

標題名稱:ehcache的三級緩存-創(chuàng)新互聯(lián)
分享鏈接:http://muchs.cn/article20/cshijo.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供微信小程序、自適應網站網站制作、建站公司、動態(tài)網站、ChatGPT

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網站建設