緩存穿透、雪崩吹榴、熱點(diǎn)擊穿問題

一個(gè)良好的緩存系統(tǒng)亭敢,往往在處理一下幾個(gè)關(guān)鍵問題上有獨(dú)到之處:緩存穿透、擊穿图筹、雪崩帅刀、熱點(diǎn)让腹、大Value等

基本位置

緩存穿透

概念

查詢肯定不存在的數(shù)據(jù),緩存不命中扣溺,懟到DB查詢骇窍。


風(fēng)險(xiǎn)

流量大時(shí),可能導(dǎo)致DB掛掉
黑客利用肉雞大規(guī)模攻擊锥余,DB掛掉

思路

BloomFilter攔截

將所有可能存在的Key Hash到一個(gè)足夠大的bitmap中腹纳,不存在的Key會(huì)被bitmap攔截,從而避免懟DB驱犹。


BloomFilter

  • 有誤判率嘲恍,會(huì)將不存在的誤判為存在,Guava BloomFilter默認(rèn)0.03
  • 但對(duì)于存在的key雄驹,一定不會(huì)誤判為不存在
  • 則發(fā)生誤判(不存在的誤判為存在)佃牛,則去查庫,這時(shí)量已降低很多

很高效管用医舆,但數(shù)據(jù)量大了也費(fèi)內(nèi)存俘侠,增加維護(hù)成本;除非要解決特定的高并發(fā)場景蔬将,不建議使用爷速。

// 1億
    private final static int SIZE = 100000000;
    private static BloomFilter<Integer> bf =BloomFilter.create(Funnels.integerFunnel(), SIZE);

    @Test
    public void testBloomFilter(){

        for (int i = 0; i < SIZE; i++) {
            bf.put(i);
        }

        long timeStart = System.nanoTime();
        if (bf.mightContain(8888)) {
            System.out.println("hit");
        }
        long timeEnd = System.nanoTime();
        System.out.println(String.format(" time = %f mm" , (timeEnd - timeStart) * 1.0/1000/1000));
    }
// 1千萬 1億級(jí)別判斷的時(shí)間基本沒差別
// 但是分配的內(nèi)存會(huì)幾乎線性變化
hit
time = 0.138511 mm

緩存空結(jié)果+過期(jetcache采用方式)

  • Key查DB返回的數(shù)據(jù)為空,仍然緩存Key : DefaultValue
  • 設(shè)置一個(gè)可容忍的過期時(shí)間

雖然過期后會(huì)重新查庫霞怀,但很大程度上能降低查庫壓力遍希,而且實(shí)現(xiàn)簡單、易維護(hù)里烦,jetcache采用的方法。

雪崩

概念

雪崩往往是由于緩存的多Key設(shè)置了相同的過期時(shí)間禁谦,某一時(shí)刻緩存多Key同時(shí)失效胁黑,所有請求全部打到DB,DB瞬時(shí)壓力過重州泊,導(dǎo)致Halt住或奔潰丧蘸。

思路

加鎖查庫(jetcache使用方式)

  • 查Cache,Key Miss遥皂,先Lock
  • 獲取到鎖的線程進(jìn)行查庫力喷,放入Cache,釋放鎖演训,喚醒其他線程
  • 其他線程等待弟孟,直到被喚醒,再查Cache(Double check)
  • 失敗样悟,則重試拂募,或返回一個(gè)默認(rèn)值(推薦)

整流隊(duì)列

  • 并發(fā)流量特別大時(shí)
  • 查DB前先通過整流器庭猩,可按key的總要程度劃分多個(gè)優(yōu)先級(jí)隊(duì)列,重要的獲取令牌百分比大
  • 獲取到令牌的進(jìn)入消費(fèi)線程池隊(duì)列
  • 多個(gè)消費(fèi)線程讀DB
  • 查DB限流
  • 線程數(shù)可控
  • 增加開發(fā)成本
  • Guava 有RateLimiter限速工具類陈症,實(shí)現(xiàn)了令牌桶算法蔼水,以一定的頻率往桶里扔令牌,線程拿到令牌才能執(zhí)行录肯。

錯(cuò)開過期時(shí)間(RD自定義)

  • 在設(shè)置過期值趴腋,在基礎(chǔ)過期時(shí)間上增加一個(gè)隨機(jī)值(如1-5分鐘隨機(jī))

熱點(diǎn)擊穿

概念

  • 某些時(shí)間點(diǎn),某些Key會(huì)被高并發(fā)地訪問论咏,形成熱點(diǎn)Key
  • 熱點(diǎn)Key恰好在這時(shí)過期了优炬,大量并發(fā)打到DB
  • 或是超高并發(fā)單Key(一般是hash到單臺(tái)機(jī)上),打滿單機(jī)的網(wǎng)卡/cpu

思路

加鎖

每個(gè)熱key的多個(gè)請求潘靖,只放過1個(gè)請求去查DB

預(yù)判超時(shí)穿剖,緩存舊值(Guava Cache的RefreshAfterWrite)

  • 在value內(nèi)部設(shè)置1個(gè)超時(shí)值t1, t1比實(shí)際的超時(shí)時(shí)間t2小
  • 當(dāng)讀時(shí)發(fā)現(xiàn)t1已過期,先加鎖延長t1并重新設(shè)置到cache, 同時(shí)通知查庫
  • 查庫期間Cache返回舊值
  • 有一個(gè)線程從數(shù)據(jù)庫加載數(shù)據(jù)并設(shè)置到cache中
  • 此后Cache返回新值

預(yù)熱(12306驗(yàn)證碼)

  • 將熱數(shù)據(jù)先加載到緩存系統(tǒng)
  • 請求直接查詢
  • 后臺(tái)線程異步同步/定時(shí)更新
  • ScheduledRefresh(定時(shí)刷新 jetcache)
  • 支持很高的并發(fā)(一般是OS系統(tǒng)層面限制卦溢、網(wǎng)卡帶寬限制)
  • 費(fèi)內(nèi)存(熱點(diǎn)過期時(shí)間很長糊余,甚至永不過期)

多級(jí)緩存

  • 熱點(diǎn)Key放在本地緩存
  • 遠(yuǎn)程緩存定時(shí)從DB更新
  • 遠(yuǎn)程緩存進(jìn)行主動(dòng)推送更新本緩存
  • 應(yīng)用節(jié)點(diǎn)不可以也是熱點(diǎn)

熱點(diǎn)動(dòng)態(tài)散列(tair熱點(diǎn)處理方式)

  • 每個(gè)HotZone都存儲(chǔ)相同的讀熱點(diǎn)數(shù)據(jù)
  • 客戶端對(duì)熱點(diǎn)數(shù)據(jù)Key的請求會(huì)隨機(jī)到任意一臺(tái)DataServer的HotZone區(qū)域
  • 單點(diǎn)的熱點(diǎn)請求就被散列到多個(gè)節(jié)點(diǎn)乃至整個(gè)集群。
  • 采用動(dòng)態(tài)散列技術(shù)单寂,在存儲(chǔ)服務(wù)端實(shí)現(xiàn)了熱點(diǎn)的再散列
  • 客戶端對(duì)熱點(diǎn)實(shí)現(xiàn)了一套單獨(dú)的邏輯
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贬芥,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子宣决,更是在濱河造成了極大的恐慌蘸劈,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尊沸,死亡現(xiàn)場離奇詭異威沫,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)洼专,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門棒掠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人屁商,你說我怎么就攤上這事烟很。” “怎么了蜡镶?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵雾袱,是天一觀的道長。 經(jīng)常有香客問我官还,道長芹橡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任望伦,我火速辦了婚禮僻族,結(jié)果婚禮上粘驰,老公的妹妹穿的比我還像新娘。我一直安慰自己述么,他們只是感情好蝌数,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著度秘,像睡著了一般顶伞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上剑梳,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天唆貌,我揣著相機(jī)與錄音,去河邊找鬼垢乙。 笑死锨咙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的追逮。 我是一名探鬼主播酪刀,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼钮孵!你這毒婦竟也來了骂倘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤巴席,失蹤者是張志新(化名)和其女友劉穎历涝,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體漾唉,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荧库,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了赵刑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片电爹。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖料睛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情摇邦,我是刑警寧澤恤煞,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站施籍,受9級(jí)特大地震影響居扒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜丑慎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一喜喂、第九天 我趴在偏房一處隱蔽的房頂上張望瓤摧。 院中可真熱鬧,春花似錦玉吁、人聲如沸照弥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽这揣。三九已至,卻和暖如春影斑,著一層夾襖步出監(jiān)牢的瞬間给赞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國打工矫户, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留片迅,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓皆辽,卻偏偏與公主長得像柑蛇,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子膳汪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

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