Cache Aside Pattern

前言

緩存是互聯(lián)網(wǎng)高并發(fā)系統(tǒng)里常用的組件笆载。由于多增加了一層,如果沒有正確的使用效果可能適得其反,諸如“緩存是刪除還是更新凉驻?”腻要,“先操作數(shù)據(jù)庫還是先操作緩存?”都是些老生常談的話題涝登,今天要介紹的是一個(gè)由 Facebook 提出的廣受認(rèn)可的緩存方案雄家。

緩存是刪除還是更新

  1. 緩存更新策略,如果緩存里面存的 value 是經(jīng)過序列化的對象胀滚,需要經(jīng)過反序列化設(shè)置新值等步驟更新成本高趟济,此時(shí)刪除緩存成本低 ,只需直接淘汰緩存咽笼,等待下次數(shù)據(jù)匯源在設(shè)置新的緩存顷编。
  2. 緩存更新策略,高并發(fā)場景有臟數(shù)據(jù)問題剑刑。
同時(shí)有請求A和請求B進(jìn)行更新操作媳纬,那么會(huì)出現(xiàn):

線程A更新了數(shù)據(jù)庫;

線程B更新了數(shù)據(jù)庫叛甫;

線程B更新了緩存层宫;

線程A更新了緩存;

這就出現(xiàn)請求A更新緩存應(yīng)該比請求B更新緩存早才對其监,但是因?yàn)榫W(wǎng)絡(luò)等原因萌腿,B卻比A更早更新了緩存。這就導(dǎo)致了臟數(shù)據(jù)抖苦,

總結(jié):更新緩存會(huì)帶來種種問題毁菱,直接刪除緩存比較簡單粗暴,穩(wěn)妥锌历。

先更新數(shù)據(jù)庫還是先操作緩存

  1. 先操作(刪除)緩存的情況贮庞,還是回到上面的高并發(fā)場景:
1. 請求A進(jìn)行寫操作,刪除緩存究西;

2. 請求B查詢發(fā)現(xiàn)緩存不存在窗慎;

3. 請求B去數(shù)據(jù)庫查詢得到舊值;

4. 請求B將舊值寫入緩存卤材;

5. 請求A將新值寫入數(shù)據(jù)庫遮斥;

此時(shí)如果緩存沒有設(shè)置超時(shí)時(shí)間,則緩存里面的數(shù)據(jù)會(huì)一直都是舊的數(shù)據(jù)扇丛。

  1. 先更新數(shù)據(jù)庫的情況术吗,這就是 Cache Aside Pattern 里的原則之一,下面分析下 case :
1. 緩存剛好失效帆精,請求A查詢數(shù)據(jù)庫较屿,得一個(gè)舊值隧魄;

2. 請求B將新值寫入數(shù)據(jù)庫;

3. 請求B刪除緩存隘蝎;

4. 請求A將查到的舊值寫入緩存购啄;

這時(shí)緩存里面確實(shí)是臟數(shù)據(jù)了,然而這種情況很小概率發(fā)生末贾。因?yàn)橹挥性诘?2 步寫數(shù)據(jù)庫的請求比第 1 步查詢數(shù)據(jù)的請求還快還會(huì)發(fā)生這種情況闸溃,由于數(shù)據(jù)庫的特性整吆,這種情況很少會(huì)存在拱撵,所以這種方案相對來說是比較可靠的。

Cache Aside Pattern

除了上面舉的例子表蝙,Cache Aside Pattern 還有幾個(gè)原則拴测。

失效:應(yīng)用程序先從cache取數(shù)據(jù),沒有得到府蛇,則從數(shù)據(jù)庫中取數(shù)據(jù)集索,成功后,放到緩存中汇跨;

命中:應(yīng)用程序從cache中取數(shù)據(jù)务荆,取到后返回;

更新:先把數(shù)據(jù)存到數(shù)據(jù)庫中穷遂,成功后函匕,再讓緩存失效;

前面兩點(diǎn)幾乎都是共識(shí)了也沒必要展開講了蚪黑,重點(diǎn)就是第 3 點(diǎn)盅惜。

參考資料:https://mp.weixin.qq.com/s/-fk-cEIo3iDCUSwT_l8d2w

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市忌穿,隨后出現(xiàn)的幾起案子抒寂,更是在濱河造成了極大的恐慌,老刑警劉巖掠剑,帶你破解...
    沈念sama閱讀 217,542評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屈芜,死亡現(xiàn)場離奇詭異,居然都是意外死亡朴译,警方通過查閱死者的電腦和手機(jī)井佑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來动分,“玉大人毅糟,你說我怎么就攤上這事±焦” “怎么了姆另?”我有些...
    開封第一講書人閱讀 163,912評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵喇肋,是天一觀的道長。 經(jīng)常有香客問我迹辐,道長蝶防,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,449評(píng)論 1 293
  • 正文 為了忘掉前任明吩,我火速辦了婚禮间学,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘印荔。我一直安慰自己低葫,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,500評(píng)論 6 392
  • 文/花漫 我一把揭開白布仍律。 她就那樣靜靜地躺著嘿悬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪水泉。 梳的紋絲不亂的頭發(fā)上善涨,一...
    開封第一講書人閱讀 51,370評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音草则,去河邊找鬼钢拧。 笑死,一個(gè)胖子當(dāng)著我的面吹牛炕横,可吹牛的內(nèi)容都是我干的源内。 我是一名探鬼主播,決...
    沈念sama閱讀 40,193評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼看锉,長吁一口氣:“原來是場噩夢啊……” “哼姿锭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起伯铣,我...
    開封第一講書人閱讀 39,074評(píng)論 0 276
  • 序言:老撾萬榮一對情侶失蹤呻此,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后腔寡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體焚鲜,經(jīng)...
    沈念sama閱讀 45,505評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,722評(píng)論 3 335
  • 正文 我和宋清朗相戀三年放前,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忿磅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,841評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡凭语,死狀恐怖葱她,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情似扔,我是刑警寧澤吨些,帶...
    沈念sama閱讀 35,569評(píng)論 5 345
  • 正文 年R本政府宣布搓谆,位于F島的核電站,受9級(jí)特大地震影響豪墅,放射性物質(zhì)發(fā)生泄漏泉手。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,168評(píng)論 3 328
  • 文/蒙蒙 一偶器、第九天 我趴在偏房一處隱蔽的房頂上張望斩萌。 院中可真熱鬧,春花似錦屏轰、人聲如沸颊郎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽袭艺。三九已至搀崭,卻和暖如春叨粘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背瘤睹。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評(píng)論 1 269
  • 我被黑心中介騙來泰國打工升敲, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人轰传。 一個(gè)月前我還...
    沈念sama閱讀 47,962評(píng)論 2 370
  • 正文 我出身青樓驴党,卻偏偏與公主長得像,于是被迫代替她去往敵國和親获茬。 傳聞我的和親對象是個(gè)殘疾皇子港庄,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,781評(píng)論 2 354

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

  • 1緩存更新的套路 常見的緩存更新套路就是旁路更新操作如下:讀:先讀緩存,讀不到就取DB讀恕曲,然后將讀到的值寫到緩存鹏氧。...
    小怪獸狂毆奧特曼閱讀 1,203評(píng)論 2 1
  • 從一個(gè)數(shù)據(jù)存儲(chǔ)按需加載數(shù)據(jù)到一個(gè)緩存中。該模式能夠提高性能并且也有助于維護(hù)緩存中的數(shù)據(jù)和底層數(shù)據(jù)存儲(chǔ)中的數(shù)據(jù)之間的...
    zlup閱讀 2,090評(píng)論 0 0
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,930評(píng)論 2 89
  • PS:轉(zhuǎn)載自《架構(gòu)師之路》吊履,覺得受益匪淺,故收錄之 緩存誤用 緩存调鬓,是互聯(lián)網(wǎng)分層架構(gòu)中艇炎,非常重要的一個(gè)部分,通常用...
    Huang遠(yuǎn)閱讀 11,234評(píng)論 4 27
  • 這是一個(gè)很可能不會(huì)寫什么腾窝,但是又想寫什么的賬號(hào)缀踪。之前陸陸續(xù)續(xù)寫過一些有的沒的腺晾,今天算是正式準(zhǔn)備找個(gè)機(jī)會(huì)默默出道啦哈...
    在海邊晃啊晃閱讀 193評(píng)論 0 0