java 腦洞 - 緩沖調(diào)用 開(kāi)源模塊

腦洞的由來(lái)

場(chǎng)景一:分頁(yè)查詢太示,某商品首頁(yè)展示
場(chǎng)景二:緩存分擔(dān)壓力,緩存失效導(dǎo)致大量請(qǐng)求去到下流服務(wù),導(dǎo)致雪崩

緩沖調(diào)用和緩存的區(qū)別

首先緩沖調(diào)用和緩存并不是互相替代的啦扬,緩沖調(diào)用是瞬點(diǎn)高并的補(bǔ)充優(yōu)化方案,在某些特殊場(chǎng)景會(huì)發(fā)揮很大的功效凫碌。緩沖調(diào)用和緩存的區(qū)別扑毡,緩沖調(diào)用不保留數(shù)據(jù),所以無(wú)需維護(hù)數(shù)據(jù)的一致性等等盛险,緩沖調(diào)用只會(huì)增加新生代內(nèi)存瞄摊,調(diào)用完之后就會(huì)刪除對(duì)應(yīng)的Future勋又,最后再討論下緩沖調(diào)用的效率問(wèn)題,緩沖調(diào)用最長(zhǎng)時(shí)間是一次完整調(diào)用换帜,最短時(shí)間是無(wú)須調(diào)用就獲得結(jié)果楔壤,所以在調(diào)用效率上也會(huì)有優(yōu)化。

更多demo請(qǐng)關(guān)注

springboot demo實(shí)戰(zhàn)項(xiàng)目
java 腦洞
java 面試寶典
開(kāi)源工具

功能描述

同一時(shí)刻多條線程攜帶同一參數(shù)調(diào)用同一接口惯驼,把調(diào)用過(guò)程包裝成FutureTask蹲嚣,每條線程通過(guò)獲取到的FutureTask獲得返回值

image.png

PS:

緩沖調(diào)用出來(lái)的對(duì)象是同一個(gè)對(duì)象,在使用時(shí)需要注意

核心源碼詳解

public <T> T execute(String callKey, long waitTime, VoidBufferCall<T> invoke) throws BufferCallException {
        // 包裝FutureTask
        Future<T> future = new FutureTask<>(() -> {
            try {
                T value = invoke.call();
                return value;
            } catch (Throwable throwable) {
                if (throwable instanceof Exception) {
                    throw (Exception) throwable;
                } else {
                    throw new Exception(throwable);
                }
            } finally {
                //  執(zhí)行完移除
                futureMap.remove(callKey);
            }
        });
        // 把FutureTask根據(jù)callKey放入Map中祟牲,如果已存在則獲取舊的FutureTask;
        Future oldFuture = futureMap.putIfAbsent(callKey, future);
        if (oldFuture == null) {
            // 如果是新的FutureTask隙畜,則執(zhí)行
            ((FutureTask) future).run();
        } else {
            future = oldFuture;
        }
        try {
            if (waitTime > 0) {
                return future.get(waitTime, TimeUnit.MILLISECONDS);
            } else {
                // 獲取調(diào)用返回值并返回
                return future.get();
            }
        } catch (Exception e) {
            throw new BufferCallException(callKey, e);
        }
    }

源碼項(xiàng)目

github : https://gitee.com/wqrzsy/lp-buffercall.git

lp-buffercall

緩沖調(diào)用的核心項(xiàng)目

lp-buffercall-spring

lp-buffercall的擴(kuò)展項(xiàng)目,引入spring來(lái)做AOP说贝,可以通過(guò)注解來(lái)實(shí)現(xiàn)調(diào)用

調(diào)用示例

@Component
public class TestService {

    @BufferCall
    public String test(@CallKey String name) {
        return name + "- Hello !";
    }

}

PS: @CallKey 如果沒(méi)有則默認(rèn)全參數(shù)

公眾號(hào)

五分鐘了解前沿技術(shù)议惰,大數(shù)據(jù),微服務(wù)乡恕,區(qū)域鏈言询,提供java前沿技術(shù)干貨,獨(dú)立游戲制作技術(shù)分享

五分鐘技術(shù)

如果這篇文章對(duì)你有幫助請(qǐng)給個(gè)star


image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末傲宜,一起剝皮案震驚了整個(gè)濱河市倍试,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蛋哭,老刑警劉巖县习,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異谆趾,居然都是意外死亡躁愿,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門沪蓬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)彤钟,“玉大人,你說(shuō)我怎么就攤上這事跷叉∫荼ⅲ” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵云挟,是天一觀的道長(zhǎng)梆砸。 經(jīng)常有香客問(wèn)我,道長(zhǎng)园欣,這世上最難降的妖魔是什么帖世? 我笑而不...
    開(kāi)封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮沸枯,結(jié)果婚禮上日矫,老公的妹妹穿的比我還像新娘赂弓。我一直安慰自己,他們只是感情好哪轿,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布盈魁。 她就那樣靜靜地躺著,像睡著了一般窃诉。 火紅的嫁衣襯著肌膚如雪杨耙。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天褐奴,我揣著相機(jī)與錄音按脚,去河邊找鬼于毙。 笑死敦冬,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的唯沮。 我是一名探鬼主播脖旱,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼介蛉!你這毒婦竟也來(lái)了萌庆?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤币旧,失蹤者是張志新(化名)和其女友劉穎践险,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體吹菱,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡巍虫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鳍刷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片占遥。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖输瓜,靈堂內(nèi)的尸體忽然破棺而出瓦胎,到底是詐尸還是另有隱情,我是刑警寧澤尤揣,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布搔啊,位于F島的核電站,受9級(jí)特大地震影響北戏,放射性物質(zhì)發(fā)生泄漏坯癣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一最欠、第九天 我趴在偏房一處隱蔽的房頂上張望示罗。 院中可真熱鬧惩猫,春花似錦、人聲如沸蚜点。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)绍绘。三九已至奶镶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間陪拘,已是汗流浹背厂镇。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留左刽,地道東北人捺信。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像欠痴,于是被迫代替她去往敵國(guó)和親迄靠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 1.JVM 堆內(nèi)存和非堆內(nèi)存 堆和非堆內(nèi)存按照官方的說(shuō)法:“Java 虛擬機(jī)具有一個(gè)堆(Heap)喇辽,堆是運(yùn)行時(shí)數(shù)據(jù)...
    yanzhu728閱讀 904評(píng)論 0 0
  • 不足的地方請(qǐng)大家多多指正掌挚,如有其它沒(méi)有想到的常問(wèn)面試題請(qǐng)大家多多評(píng)論,一起成長(zhǎng)菩咨,感謝!~ String可以被繼承嗎...
    啟示錄是真的閱讀 2,924評(píng)論 3 3
  • 1吠式、面向?qū)ο蟮奶卣饔心男┓矫? 答:面向?qū)ο蟮奶卣髦饕幸韵聨讉€(gè)方面: -- 抽象:抽象是將一類對(duì)象的共同特征總結(jié)...
    ccc_74bd閱讀 973評(píng)論 0 1
  • 1.StringBuffer與String的區(qū)別 StringBuffer是線程安全的,每次操作字符串抽米,Strin...
    zdd5457閱讀 988評(píng)論 0 5
  • 包含的重點(diǎn)內(nèi)容:JAVA基礎(chǔ)JVM 知識(shí)開(kāi)源框架知識(shí)操作系統(tǒng)多線程TCP 與 HTTP架構(gòu)設(shè)計(jì)與分布式算法數(shù)據(jù)庫(kù)知...
    消失er閱讀 4,308評(píng)論 1 10