摘要:是由阿里巴巴開源的通用緩存訪問框架,如果你對(duì)很熟悉的話,請(qǐng)一定花一點(diǎn)時(shí)間了解一下,它更好用。有了,我們就可以更方便的基于統(tǒng)一的接口訪問緩存。
JetCache是由阿里巴巴開源的通用緩存訪問框架,如果你對(duì)Spring Cache很熟悉的話,請(qǐng)一定花一點(diǎn)時(shí)間了解一下JetCache,它更好用。
JetCache提供的核心能力包括:
提供統(tǒng)一的,類似jsr-107風(fēng)格的API訪問Cache,并可通過注解創(chuàng)建并配置Cache實(shí)例
通過注解實(shí)現(xiàn)聲明式的方法緩存,支持TTL和兩級(jí)緩存
分布式緩存自動(dòng)刷新,分布式鎖 (2.2+)
支持異步Cache API
Spring Boot支持
Key的生成策略和Value的序列化策略是可以定制的
針對(duì)所有Cache實(shí)例和方法緩存的自動(dòng)統(tǒng)計(jì)
我們直接看代碼,最簡(jiǎn)單的使用場(chǎng)景是這樣的:
public interface UserService { @Cached(expire = 3600, cacheType = CacheType.REMOTE) User getUserById(long userId); }
這和Spring Cache很像,不過@Cached注解原生支持了TTL(超時(shí)時(shí)間),cacheType有LOCAL/REMOTE/BOTH三種選擇,
分別代表本地內(nèi)存/遠(yuǎn)程Cache Server(例如Redis)/兩級(jí)緩存,可根據(jù)情況選用,合理的使用LOCAL或BOTH類型可以降低Cache Server的壓力以及我們提供的服務(wù)的響應(yīng)時(shí)間。
再看個(gè)復(fù)雜點(diǎn)的例子:
public interface UserService { @Cached(name="userCache-", key="#userId", expire = 3600) User getUserById(long userId); @CacheUpdate(name="userCache-", key="#user.userId", value="#user") void updateUser(User user); @CacheInvalidate(name="userCache-", key="#userId") void deleteUser(long userId); }
第一個(gè)例子中我們沒有指定key,JetCache會(huì)根據(jù)參數(shù)自動(dòng)生成,這個(gè)例子我們指定了key,并且展示了緩存的更新和刪除。
自動(dòng)刷新是JetCache的大殺器:
public interface SummaryService{ @Cached(expire = 3600, cacheType = CacheType.REMOTE) @CacheRefresh(refresh = 1800, stopRefreshAfterLastAccess = 3600, timeUnit = TimeUnit.SECONDS) BigDecimal salesVolumeSummary(int timeId, long catagoryId); }
cacheType為REMOTE或者BOTH的時(shí)候,刷新行為是全局唯一的,也就是說,即使應(yīng)用服務(wù)器是一個(gè)集群,也不會(huì)出現(xiàn)多個(gè)服務(wù)器同時(shí)去刷新一個(gè)key的情況。
一個(gè)key的刷新任務(wù),自該key首次被訪問后初始化,如果該key長(zhǎng)時(shí)間不被訪問,在stopRefreshAfterLastAccess指定的時(shí)間后,相關(guān)的刷新任務(wù)就會(huì)被自動(dòng)移除,這樣就避免了浪費(fèi)資源去進(jìn)行沒有意義的刷新。
加在方法上的注解畢竟不能提供最靈活的控制,所以JetCache提供了Cache API,使用起來就像Map一樣:
UserDO user = userCache.get(12345L); userCache.put(12345L, loadUserFromDataBase(12345L)); userCache.remove(12345L); userCache.computeIfAbsent(1234567L, (key) -> loadUserFromDataBase(1234567L));
實(shí)際上Cache API實(shí)現(xiàn)了jsr107規(guī)范Cache接口的部分方法,以后的大版本可能會(huì)完整實(shí)現(xiàn)。
Cache實(shí)例可以通過注解創(chuàng)建:
@CreateCache(expire = 100, cacheType = CacheType.BOTH, localLimit = 50) private CacheuserCache;
也可以通過和guava cache/caffeine類似的builder來創(chuàng)建:
GenericObjectPoolConfig pc = new GenericObjectPoolConfig(); pc.setMinIdle(2); pc.setMaxIdle(10); pc.setMaxTotal(10); JedisPool pool = new JedisPool(pc, "localhost", 6379); CacheuserCache = RedisCacheBuilder.createRedisCacheBuilder() .keyConvertor(FastjsonKeyConvertor.INSTANCE) .valueEncoder(JavaValueEncoder.INSTANCE) .valueDecoder(JavaValueDecoder.INSTANCE) .jedisPool(pool) .keyPrefix("userCache-") .expireAfterWrite(200, TimeUnit.SECONDS) .buildCache();
Cache接口支持異步:
CacheGetResult r = cache.GET(userId); CompletionStagefuture = r.future(); future.thenRun(() -> { if(r.isSuccess()){ System.out.println(r.getValue()); } });
可以實(shí)現(xiàn)不嚴(yán)格的分布式鎖:
cache.tryLockAndRun("key", 60, TimeUnit.SECONDS, () -> heavyDatabaseOperation());
使用Cache API也可以做自動(dòng)刷新哦:
@CreateCache @CacheRefresh(timeUnit = TimeUnit.MINUTES, refresh = 60) private CacheorderSumCache; @PostConstruct public void init(){ orderSumCache.config().setLoader(this::loadOrderSumFromDatabase); }
如果沒有使用注解,用builder一樣也可以做出自動(dòng)刷新:
CacheorderSumCache = RedisCacheBuilder.createRedisCacheBuilder() ......省略 .refreshPolicy(RefreshPolicy.newPolicy(60, TimeUnit.SECONDS)) .loader(this::loadOrderSumFromDatabase) .buildCache();
當(dāng)前支持的緩存系統(tǒng)包括以下4個(gè),而且要支持一種新的緩存也是非常容易的:
Caffeine(基于本地內(nèi)存)
LinkedHashMap(基于本地內(nèi)存,JetCache自己實(shí)現(xiàn)的簡(jiǎn)易LRU緩存)
Alibaba Tair(相關(guān)實(shí)現(xiàn)未在Github開源,在阿里內(nèi)部Gitlab上可以找到)
Redis
使用JetCache的系統(tǒng)需求:
JDK:必須Java 8
Spring Framework:4.0.8以上,如果不使用注解就不需要
Spring Boot:1.1.9以上(可選)
更多文檔可以在github的wiki上找到。
有了JetCache,我們就可以更方便的基于統(tǒng)一的接口訪問緩存。
詳情請(qǐng)閱讀原文
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/69243.html
摘要:是一個(gè)基于的緩存系統(tǒng)封裝,提供統(tǒng)一的和注解來簡(jiǎn)化緩存的使用。提供了比更加強(qiáng)大的注解,可以原生的支持兩級(jí)緩存分布式自動(dòng)刷新,還提供了接口用于手工緩存操作。緩存失效時(shí)間緩存的類型,包括。 之前一直在用Spring Cache進(jìn)行接口數(shù)據(jù)的緩存,主要是Spring Cache在對(duì)具體key緩存失效時(shí)間的設(shè)置不是很方法,還要自己去擴(kuò)展,無意中發(fā)現(xiàn)了阿里的JetCache。大部分的需求都能滿足,...
摘要:降級(jí)往往會(huì)指定不同的級(jí)別,面臨不同的異常等級(jí)執(zhí)行不同的處理。談?wù)勀銓?duì)和的認(rèn)識(shí)兩者關(guān)系具體可以看公眾號(hào)阿里巴巴中間件的這篇文章獨(dú)家解讀從微服務(wù)框架到微服務(wù)生態(tài)與并不是競(jìng)爭(zhēng)關(guān)系,作為成熟的框架,其易用性擴(kuò)展性和健壯性已得到業(yè)界的認(rèn)可。 該文已加入筆主的開源項(xiàng)目——JavaGuide(一份涵蓋大部分Java程序員所需要掌握的核心知識(shí)的文檔類項(xiàng)目),地址:https://github.com/...
摘要:降級(jí)往往會(huì)指定不同的級(jí)別,面臨不同的異常等級(jí)執(zhí)行不同的處理。談?wù)勀銓?duì)和的認(rèn)識(shí)兩者關(guān)系具體可以看公眾號(hào)阿里巴巴中間件的這篇文章獨(dú)家解讀從微服務(wù)框架到微服務(wù)生態(tài)與并不是競(jìng)爭(zhēng)關(guān)系,作為成熟的框架,其易用性擴(kuò)展性和健壯性已得到業(yè)界的認(rèn)可。 該文已加入筆主的開源項(xiàng)目——JavaGuide(一份涵蓋大部分Java程序員所需要掌握的核心知識(shí)的文檔類項(xiàng)目),地址:https://github.com/...
閱讀 2997·2021-10-19 11:46
閱讀 989·2021-08-03 14:03
閱讀 2949·2021-06-11 18:08
閱讀 2921·2019-08-29 13:52
閱讀 2774·2019-08-29 12:49
閱讀 493·2019-08-26 13:56
閱讀 934·2019-08-26 13:41
閱讀 856·2019-08-26 13:35