快取穿透
快取穿透是指,請求獲取的資料來源不存在,redis沒有則會去請求資料庫,資料庫也沒有,這時候大量請求可能會壓垮資料庫。
快取擊穿
快取擊穿是指,請求獲取的某個redis key剛好過期,資料庫中有資料,這時候大量的請求就落到的資料庫上,造成資料庫掛掉。
快取雪崩
快取雪崩是指,有大量的redis key過期,這時候大量請求落到資料庫,造成資料庫壓力很大。
快取穿透的解決方案
針對快取穿透,可以直接給請求不存在的資料redis存乙個null,但是要設定時間(30s)不能太長,太長會導致資料長時間不更新。
在請求錢提前驗證資料是否存在 比如資料庫id是自增的,直接過濾掉請求中id<0的一些請求
使用布隆過濾器,所有可能存在的資料雜湊儲存在bitmap中,乙個一定不存在的資料就會被攔截
快取擊穿的解決方案
設定redis key永不過期
使用互斥鎖
在快取失效的時候,不直接去請求資料庫,使用redis的setnx設定乙個 mutex_key,在這個時候去快取資料庫的資料,其他執行緒都先等待。
快取雪崩的解決方案
快取資料設定隨機過期時間,防止大量資料同一時間過期
設定資料永不過期
快取穿透 快取擊穿 快取雪崩
一 快取處理流程 前台請求,後台先從快取中取資料,取到直接返回結果,取不到時從資料庫中取,資料庫取到更新快取,並返回結果,資料庫也沒取到,那直接返回空結果。二 快取穿透 描述 快取穿透是指快取和資料庫中都沒有的資料,而使用者不斷發起請求,如發起為id為 1 的資料或id為特別大不存在的資料。這時的使...
快取穿透,快取擊穿,快取雪崩
所謂的快取穿透,簡單來講就是查詢某些不存在的key時,快取和資料庫查詢結果都為空,而空的結果又不被快取起來,而導致每次查詢都去請求資料庫層的情況。在流量大時,可能db就掛掉了,要是有人利用不存在的key頻繁攻擊我們的應用,這就是漏洞。過程 快取不命中,進而導致每次查詢都去查詢資料庫,快取也就失去了作...
快取穿透快取擊穿快取雪崩
1 快取穿透 1.1 什麼是快取穿透 快取穿透,是指查詢乙個資料庫一定不存在的資料 核心 快取和資料庫該值不存在 正常的使用快取流程大致是,資料查詢先進行快取查詢,如果key不存在或者key已經過期,再對資料庫進行查詢,並把查詢到的物件,放進快取。如果資料庫查詢物件為空,則不放進快取。1.2 帶來的...