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

2022-01-29 07:07:07 字數 596 閱讀 8229

這篇文章,我們將介紹什麼是快取穿透、快取擊穿與快取雪崩,以及對應的解決方案。

1.快取穿透

快取穿透,是指查詢乙個不存在的資料,由於資料不存在,所以資料不會被快取,每次查詢都是從資料庫中去查詢。如果有人利用這個存在的漏洞去偽造大量的請求,那麼很可能導致db承受不了那麼大的流量就掛掉了。

解決方案:

2.快取擊穿

快取擊穿,就是在熱點key失效的瞬間,海量的請求訪問資料庫,導致資料庫崩潰。

解決方案:

3.快取雪崩

快取雪崩,是指我們設定快取時採用了相同的過期時間,導致很多key在某一時刻同時失效,請求全部**到資料庫,最終導致資料庫瞬時壓力過大而崩潰。

解決方案:

總結:快取穿透是業務層面的漏洞導致非法請求,與請求量、快取失效沒關係。快取擊穿則只會出現在熱點資料上,發生在快取失效的瞬間,與業務沒多大關係。快取雪崩則是因為多個 key 同時失效,導致資料庫請求太多。非熱點資料也會導致快取雪崩,只要同時失效的 key 足夠多。

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

從第乙個快取框架 memcached 誕生以來,快取就廣泛地存在於網際網路應用中。如果你的應用流量很小,那麼使用快取可能並不需要做多餘的考慮。但如果你的應用流量達到了成百上千萬,那麼你就不得不考慮深層次的快取問題 快取穿透 快取擊穿與快取雪崩。快取穿透是指查詢乙個一定不存在的資料,因為這個資料不存在...

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

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

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

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