如何處理緩存失效桥胞、緩存穿透恳守、緩存并發(fā)等問題


緩存失效###

原因:引起這個原因的主要因素是高并發(fā)下,我們一般設(shè)定一個緩存的過期時間時贩虾,可能有一些會設(shè)置5分鐘啊催烘,10分鐘這些;并發(fā)很高時可能會出在某一個時間同時生成了很多的緩存缎罢,并且過期時間在同一時刻伊群,這個時候就可能引發(fā)——當過期時間到后,這些緩存將同時失效策精。

影響:緩存同時失效時產(chǎn)生的雪崩效應(yīng)昂秃,將所有請求全部放在數(shù)據(jù)庫上童太,這樣很容易就達到數(shù)據(jù)庫的瓶頸,導致服務(wù)無法正常提供。盡量避免這種場景的發(fā)生斩祭。

解決:一個簡單方案就是將緩存失效時間分散開,不要所以緩存時間長度都設(shè)置成5分鐘或者10分鐘;比如我們可以在原有的失效時間基礎(chǔ)上增加一個隨機值,比如1-5分鐘隨機抽莱,這樣每一個緩存的過期時間的重復率就會降低,就很難引發(fā)集體失效的事件骄恶。

緩存穿透###

場景:指查詢一個一定不存在的數(shù)據(jù)食铐,由于緩存是不命中時被動寫的,并且出于容錯考慮僧鲁,如果從存儲層查不到數(shù)據(jù)則不寫入緩存虐呻,這將導致這個不存在的數(shù)據(jù)每次請求都要到存儲層去查詢,失去了緩存的意義寞秃。

影響:當在流量較大時斟叼,出現(xiàn)這樣的情況,一直請求DB春寿,很容易導致服務(wù)掛掉朗涩。

解決:

  1. 在封裝的緩存SET和GET部分增加個步驟,如果查詢一個KEY不存在绑改,就已這個KEY為前綴設(shè)定一個標識KEY谢床;以后再查詢該KEY的時候,先查詢標識KEY厘线,如果標識KEY存在识腿,就返回一個協(xié)定好的非false或者NULL值,然后APP做相應(yīng)的處理造壮,這樣緩存層就不會被穿透渡讼。當然這個驗證KEY的失效時間不能太長。

  2. 如果一個查詢返回的數(shù)據(jù)為空(不管是數(shù)據(jù)不存在费薄,還是系統(tǒng)故障)硝全,我們?nèi)匀话堰@個空結(jié)果進行緩存,但它的過期時間會很短楞抡,一般只有幾分鐘伟众。

  3. 采用布隆過濾器,將所有可能存在的數(shù)據(jù)哈希到一個足夠大的bitmap中召廷,一個一定不存在的數(shù)據(jù)會被這個bitmap攔截掉凳厢,從而避免了對底層存儲系統(tǒng)的查詢壓力。

緩存并發(fā)###

場景:當網(wǎng)站并發(fā)訪問高竞慢,一個緩存如果失效先紫,可能出現(xiàn)多個進程同時查詢DB,同時設(shè)置緩存的情況筹煮,如果并發(fā)確實很大遮精,這也可能造成DB壓力過大,還有緩存頻繁更新的問題。

解決:對緩存查詢加鎖本冲,如果KEY不存在准脂,就加鎖,然后查DB入緩存檬洞,然后解鎖狸膏;其他進程如果發(fā)現(xiàn)有鎖就等待,然后等解鎖后返回數(shù)據(jù)或者進入DB查詢添怔。

來源:http://www.cnblogs.com/lingshao/p/5658757.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末湾戳,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子广料,更是在濱河造成了極大的恐慌砾脑,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件艾杏,死亡現(xiàn)場離奇詭異拦止,居然都是意外死亡,警方通過查閱死者的電腦和手機糜颠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來萧求,“玉大人其兴,你說我怎么就攤上這事】湔” “怎么了元旬?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長守问。 經(jīng)常有香客問我匀归,道長,這世上最難降的妖魔是什么耗帕? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任穆端,我火速辦了婚禮,結(jié)果婚禮上仿便,老公的妹妹穿的比我還像新娘体啰。我一直安慰自己,他們只是感情好嗽仪,可當我...
    茶點故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布荒勇。 她就那樣靜靜地躺著,像睡著了一般闻坚。 火紅的嫁衣襯著肌膚如雪沽翔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天窿凤,我揣著相機與錄音仅偎,去河邊找鬼跨蟹。 笑死,一個胖子當著我的面吹牛哨颂,可吹牛的內(nèi)容都是我干的喷市。 我是一名探鬼主播,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼威恼,長吁一口氣:“原來是場噩夢啊……” “哼品姓!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起箫措,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤腹备,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后斤蔓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體植酥,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年弦牡,在試婚紗的時候發(fā)現(xiàn)自己被綠了友驮。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡驾锰,死狀恐怖卸留,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情椭豫,我是刑警寧澤耻瑟,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站赏酥,受9級特大地震影響喳整,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜裸扶,卻給世界環(huán)境...
    茶點故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一框都、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧姓言,春花似錦瞬项、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至餐塘,卻和暖如春妥衣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工税手, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蜂筹,地道東北人。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓芦倒,卻偏偏與公主長得像艺挪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子兵扬,可洞房花燭夜當晚...
    茶點故事閱讀 43,494評論 2 348

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