數(shù)據(jù)緩存的處理

一.緩存更新策略

典型的緩存模式职车,一般有如下幾種:

  • Cache Aside

  • Read/Write Through

  • Write Behind

1.Cache Aside 模式

這是大家經(jīng)常用到的一種策略模式愉择。這種模式主要流程如下:

  • 應(yīng)用在查詢數(shù)據(jù)的時候债蓝,先從緩存Cache中讀取數(shù)據(jù),如果緩存中沒有欠窒,則再從數(shù)據(jù)庫中讀取數(shù)據(jù)助币,得到數(shù)據(jù)庫的數(shù)據(jù)之后蓬网,將這個數(shù)據(jù)也放到緩存Cache中。

  • 如果應(yīng)用要更新某個數(shù)據(jù)楣嘁,也是先去更新數(shù)據(jù)庫中的數(shù)據(jù)磅轻,更新完成之后,則通過指令讓緩存Cache中的數(shù)據(jù)失效逐虚。

這里為什么不讓更新操作在寫完數(shù)據(jù)庫之后聋溜,緊接著去把緩存Cache中的數(shù)據(jù)也修改了呢?

主要是因?yàn)檫@樣做的話叭爱,就有2個寫操作的事件了撮躁,擔(dān)心在并發(fā)的情況下會導(dǎo)致臟數(shù)據(jù),舉個例子:
假如同時有2個請求买雾,請求A和請求B馒胆,并發(fā)的執(zhí)行。請求A是要去讀數(shù)據(jù)凝果,請求B是要去更新數(shù)據(jù)祝迂。初始狀態(tài)緩存中是沒有數(shù)據(jù)的,當(dāng)請求A讀到數(shù)據(jù)之后器净,準(zhǔn)備往回寫的時候型雳,此刻,請求B正好要更新數(shù)據(jù),更新完了數(shù)據(jù)庫之后纠俭,又去把緩存更新了沿量,那請求A再往緩存中寫的就是舊數(shù)據(jù)了,屬于臟數(shù)據(jù)冤荆。

那么 Cache Aside 模式就沒有臟數(shù)據(jù)問題了嗎朴则?不是的,在極端情況下也可能會產(chǎn)生臟數(shù)據(jù)钓简,比如:

假如同時有2個請求乌妒,請求A和請求B,并發(fā)的執(zhí)行外邓。請求A是要去讀數(shù)據(jù)撤蚊,請求B是要去寫數(shù)據(jù)。假如初始狀態(tài)緩存中沒有這個數(shù)據(jù)损话,那請求A發(fā)現(xiàn)緩存中沒有數(shù)據(jù)侦啸,就會去數(shù)據(jù)庫中讀數(shù)據(jù),讀到了數(shù)據(jù)準(zhǔn)備寫回緩存中丧枪,就在這個時候光涂,請求B是要去寫數(shù)據(jù)的,請求B在寫完數(shù)據(jù)庫的數(shù)據(jù)之后拧烦,又去設(shè)置了緩存失效忘闻。這個時候,請求A由于在數(shù)據(jù)庫中讀到了之前的舊數(shù)據(jù)屎篱,開始往緩存中寫數(shù)據(jù)了服赎,此時寫進(jìn)入的就也是舊數(shù)據(jù)。那么最終就會導(dǎo)致交播,緩存中的數(shù)據(jù)與數(shù)據(jù)庫的數(shù)據(jù)不一致重虑,造成了臟數(shù)據(jù)。

不過這種概率比上面一種概率要小很多秦士。所以整體而言 Cache Aside 模式 還是一種比較簡單實(shí)用的方式缺厉。

2.Read/Write Through 模式

這個模式其實(shí)就是將 緩存服務(wù) 作為主要的存儲,應(yīng)用的所有讀寫請求都是直接與緩存服務(wù)打交道隧土,而不管最后端的數(shù)據(jù)庫了提针,數(shù)據(jù)庫的數(shù)據(jù)由緩存服務(wù)來維護(hù)和更新。不過緩存中數(shù)據(jù)變更的時候是同步去更新數(shù)據(jù)庫的曹傀,在應(yīng)用的眼中只有緩存服務(wù)辐脖。

流程就相當(dāng)簡單了:

  • 應(yīng)用要讀數(shù)據(jù)和更新數(shù)據(jù)都直接訪問緩存服務(wù)

  • 緩存服務(wù)同步的將數(shù)據(jù)更新到數(shù)據(jù)庫

這個模式出現(xiàn)臟數(shù)據(jù)的概率就比較低,但是就強(qiáng)依賴緩存了皆愉,對緩存服務(wù)的穩(wěn)定性有較大要求嗜价,另外艇抠,增加新緩存節(jié)點(diǎn)時還會有初始狀態(tài)空數(shù)據(jù)問題。

3.Write Behind 模式

這個模式就是 Read/Write Through 模式 的一個變種久锥。區(qū)別就是 Read/Write Through 模式的緩存寫數(shù)據(jù)庫的時候是同步的家淤,而 Write Behind 模式 的緩存操作數(shù)據(jù)庫是異步的。

流程如下:

  • 應(yīng)用要讀數(shù)據(jù)和更新數(shù)據(jù)都直接訪問緩存服務(wù)

  • 緩存服務(wù)異步的將數(shù)據(jù)更新到數(shù)據(jù)庫(通過異步任務(wù))

這個模式的特點(diǎn)就是速度很快瑟由,效率會非常高絮重,但是數(shù)據(jù)的一致性比較差,還可能會有數(shù)據(jù)的丟失情況歹苦,實(shí)現(xiàn)邏輯也較為復(fù)雜青伤。

以上就是目前三種主流的緩存更新策略,另外還有Refrsh-Ahead模式等由于使用的不是很常見就不詳細(xì)介紹了暂氯。

二.緩存相關(guān)

1.緩存擊穿

緩存擊穿是指緩存中沒有但數(shù)據(jù)庫中有的數(shù)據(jù)(一般是緩存時間到期)潮模,這時由于并發(fā)用戶特別多亮蛔,同時讀緩存沒讀到數(shù)據(jù)痴施,又同時去數(shù)據(jù)庫去取數(shù)據(jù),引起數(shù)據(jù)庫壓力瞬間增大究流,造成過大壓力
解決方案:

  • 設(shè)置熱點(diǎn)數(shù)據(jù)永遠(yuǎn)不過期辣吃。
  • 加互斥鎖,互斥鎖參考代碼如下:

2.緩存穿透

緩存穿透是指緩存和數(shù)據(jù)庫中都沒有的數(shù)據(jù)芬探,而用戶不斷發(fā)起請求神得,如發(fā)起為id為“-1”的數(shù)據(jù)或id為特別大不存在的數(shù)據(jù)。這時的用戶很可能是攻擊者偷仿,攻擊會導(dǎo)致數(shù)據(jù)庫壓力過大哩簿。
解決方案:

  • 布隆過濾器 接口層增加校驗(yàn),如用戶鑒權(quán)校驗(yàn)酝静,id做基礎(chǔ)校驗(yàn)节榜,id<=0的直接攔截;
  • 從緩存取不到的數(shù)據(jù)别智,在數(shù)據(jù)庫中也沒有取到宗苍,這時也可以將key-value對寫為key-null,緩存有效時間可以設(shè)置短點(diǎn)薄榛,如30秒(設(shè)置太長會導(dǎo)致正常情況也沒法使用)讳窟。這樣可以防止攻擊用戶反復(fù)用同一個id暴力攻擊

3.緩存雪崩

緩存雪崩是指緩存中數(shù)據(jù)大批量到過期時間,而查詢數(shù)據(jù)量巨大敞恋,引起數(shù)據(jù)庫壓力過大甚至down機(jī)丽啡。和緩存擊穿不同的是, 緩存擊穿指并發(fā)查同一條數(shù)據(jù)硬猫,緩存雪崩是不同數(shù)據(jù)都過期了补箍,很多數(shù)據(jù)都查不到從而查數(shù)據(jù)庫倚评。

解決方案:

  • 緩存數(shù)據(jù)的過期時間設(shè)置隨機(jī),防止同一時間大量數(shù)據(jù)過期現(xiàn)象發(fā)生馏予。
  • 如果緩存數(shù)據(jù)庫是分布式部署天梧,將熱點(diǎn)數(shù)據(jù)均勻分布在不同的緩存數(shù)據(jù)庫中。
  • 設(shè)置熱點(diǎn)數(shù)據(jù)永遠(yuǎn)不過期霞丧。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末呢岗,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蛹尝,更是在濱河造成了極大的恐慌后豫,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件突那,死亡現(xiàn)場離奇詭異挫酿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)愕难,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門早龟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人猫缭,你說我怎么就攤上這事葱弟。” “怎么了猜丹?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵芝加,是天一觀的道長。 經(jīng)常有香客問我射窒,道長藏杖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任脉顿,我火速辦了婚禮蝌麸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘弊予。我一直安慰自己祥楣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布汉柒。 她就那樣靜靜地躺著误褪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪碾褂。 梳的紋絲不亂的頭發(fā)上兽间,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天,我揣著相機(jī)與錄音正塌,去河邊找鬼嘀略。 笑死恤溶,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的帜羊。 我是一名探鬼主播咒程,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼讼育!你這毒婦竟也來了帐姻?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤奶段,失蹤者是張志新(化名)和其女友劉穎饥瓷,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體痹籍,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡呢铆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蹲缠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棺克。...
    茶點(diǎn)故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖吼砂,靈堂內(nèi)的尸體忽然破棺而出逆航,到底是詐尸還是另有隱情鼎文,我是刑警寧澤渔肩,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站拇惋,受9級特大地震影響周偎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜撑帖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一蓉坎、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧胡嘿,春花似錦蛉艾、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至缴罗,卻和暖如春助琐,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背面氓。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工兵钮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蛆橡,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓掘譬,卻偏偏與公主長得像泰演,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子葱轩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評論 2 361

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