快取穿透 快取擊穿 快取雪崩及其解決方案

2021-10-24 13:32:01 字數 674 閱讀 6761

快取穿透:指查詢乙個一定不存在的資料,如果從儲存層查不到資料則不寫入快取,這將 導致這個不存在的資料每次請求都要到 db 去查詢,可能導致 db 掛掉。

解決方案:1.查詢返回的資料為空,仍把這個空結果進行快取,但過期時間會比較短;2.布 隆過濾器:將所有可能存在的資料雜湊到乙個足夠大的 bitmap 中,乙個一定不存在的資料 會被這個 bitmap 攔截掉,從而避免了對 db 的查詢。

快取擊穿:對於設定了過期時間的 key,快取在某個時間點過期的時候,恰好這時間點對 這個 key 有大量的併發請求過來,這些請求發現快取過期一般都會從後端 db 載入資料並 回設到快取,這個時候大併發的請求可能會瞬間把 db 壓垮。

解決方案:1.使用互斥鎖:當快取失效時,不立即去 load db,先使用如 redis 的 setnx 去設 置乙個互斥鎖,當操作成功返回時再進行 load db 的操作並回設快取,否則重試 get 快取的 方法。2.永遠不過期:物理不過期,但邏輯過期(後台非同步執行緒去重新整理)。

快取雪崩:設定快取時採用了相同的過期時間,導致快取在某一時刻同時失效,請求全部 **到 db,db 瞬時壓力過重雪崩。與快取擊穿的區別:雪崩是很多 key,擊穿是某乙個 key 快取。

解決方案:將快取失效時間分散開,比如可以在原有的失效時間基礎上增加乙個隨機值, 比如 1-5 分鐘隨機,這樣每乙個快取的過期時間的重複率就會降低,就很難引發集體失效 的事件。

快取穿透 快取擊穿 快取雪崩

一 快取處理流程 前台請求,後台先從快取中取資料,取到直接返回結果,取不到時從資料庫中取,資料庫取到更新快取,並返回結果,資料庫也沒取到,那直接返回空結果。二 快取穿透 描述 快取穿透是指快取和資料庫中都沒有的資料,而使用者不斷發起請求,如發起為id為 1 的資料或id為特別大不存在的資料。這時的使...

快取穿透,快取擊穿,快取雪崩

所謂的快取穿透,簡單來講就是查詢某些不存在的key時,快取和資料庫查詢結果都為空,而空的結果又不被快取起來,而導致每次查詢都去請求資料庫層的情況。在流量大時,可能db就掛掉了,要是有人利用不存在的key頻繁攻擊我們的應用,這就是漏洞。過程 快取不命中,進而導致每次查詢都去查詢資料庫,快取也就失去了作...

快取穿透快取擊穿快取雪崩

1 快取穿透 1.1 什麼是快取穿透 快取穿透,是指查詢乙個資料庫一定不存在的資料 核心 快取和資料庫該值不存在 正常的使用快取流程大致是,資料查詢先進行快取查詢,如果key不存在或者key已經過期,再對資料庫進行查詢,並把查詢到的物件,放進快取。如果資料庫查詢物件為空,則不放進快取。1.2 帶來的...