關於快取擊穿 快取雪崩 快取穿透

2021-09-26 05:01:34 字數 933 閱讀 6549

設計乙個快取系統,不得不要考慮的問題就是:快取穿透、快取擊穿與失效時的雪崩效應。

快取穿透是指查詢乙個在db中根本不存在的key,由於快取一般是不命中時被動寫入的,如果從儲存層查不到資料是不寫入快取,這將導致這個不存在的資料請求每次都要請求到儲存層,失去了快取的意義,流量大的時候,可能會導致db宕機。

1、採用布隆過濾器,將所有可能存在的資料雜湊到乙個足夠大的bitmap中,請求到來的時候先從這個bitmap過濾請求key,如果key不存在就會被這個bitmap過濾掉,從而避免了對底層儲存系統的查詢壓力,

2、快取空物件,對乙個key如果查詢資料不存在,則仍然在快取中儲存這個key,value為空物件,並且設乙個比較短的過期時間

快取雪崩是指我們為key設定了相同的快取過期時間,導致快取在某乙個時刻同時失效,請求全部**到db,db瞬時壓力過重雪崩

快取失效時的雪崩效應對底層系統的衝擊是非常可怕的,大多數系統設計者考慮使用加鎖或者佇列的方式保證快取的單執行緒讀寫,從而避免快取失效期間大量的併發請求落到底層儲存系統上。

1、加鎖限流:加鎖控制對db的請求數量

2、將快取失效時間分散開,可以在原有的失效時間基礎上增加乙個隨機值,這樣每乙個快取的過期時間的重複率就會變低,避免集體失效的事件。

對一些設定了過期時間的key,如果這些可以在某個時間點被高併發訪問,是一種非常熱點的資料,這時候如果這些快取被擊穿,這個和快取雪崩的區別就是這裡是針對某乙個key的快取,快取雪崩式針對很對key

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

解決方案:

1、永不過期

2、使用互斥鎖(mutex key): 這種解決方案思路比較簡單,就是只讓乙個執行緒構建快取,其他執行緒等待構建快取的執行緒執行完,重新從快取獲取資料就可以了

參考:

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

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

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

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

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

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