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

2021-10-23 06:47:47 字數 734 閱讀 7929

快取穿透

當使用者惡意請求,在短時間內傳送大量請求,訪問乙個一定不存在的key,這個時候請求就會集中跑到資料庫中,資料庫由於承受不了這麼大的壓力,就有可能發生系統崩潰。

解決方案

有很多種方法可以有效的解決快取穿透問題,最常見的就是利用布隆過濾器,將那些可能存在的key存放在bitmap中,對於那些一定不存在的key就行過濾,

被bitmap攔截掉,從而避免了對資料庫的查詢壓力。還有一種辦法就是,當查詢到乙個結果時,即使為空,也放到快取當中,然後設定一定的過期時間,不要太長,最長不超過五分鐘。

快取擊穿

乙個存在的key,在快取過期的一刻,同時有大量的請求,這些請求都會擊穿到db,造成瞬時db請求量大、壓力驟增,就會全部堆積到資料庫當中。

解決辦法

當通過某乙個key去查詢資料的時候,如果對應在資料庫中的資料都不存在,我們將此key對應的value設定為乙個預設的值,比如「null」,並設定乙個快取的失效時間,這時在快取失效之前,所有通過此key的訪問都被快取擋住了。後面如果此key對應的資料在db中存在時,快取失效之後,通過此key再去訪問資料,就能拿到新的value了。

快取雪崩

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

1、可以給快取設定過期時間時加上乙個隨機值時間,使得每個key的過期時間分布開來,不會集中在同一時刻失效。

2、一般併發量不是特別多的時候,使用最多的解決方案是加鎖排隊。

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

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

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

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

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

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