快取穿透 快取雪崩 快取擊穿 布隆演算法

2022-05-08 14:27:10 字數 1109 閱讀 5584

一、快取穿透

去快取層沒有查到資料,而去資料庫中查詢資料。

注意:不能避免低頻的快取穿透,可以避免高頻的快取穿透。

二、快取雪崩

快取層的資料,在某一時刻突然失效(無法訪問),導致大量的請求跑到資料庫。

導致原因:

(1)redis中快取的資料有效期是一致的。

(2)redis資料庫掛掉了

解決辦法:分布式快取

三、redis集群的hash一致性演算法

解決redie集群中再新增redis資料庫的資料儲存問題。

三、快取擊穿

當快取層(redis)只快取了1條資料時,當使用者大量的請求過來時,剛好這條資料失效。

解決辦法:分布式鎖(基於mysql或者基於zookeeper)

四、布隆演算法

通過一定的錯誤率換取空間,錯誤率是由於存在hash碰撞導致的,降低錯誤率的方法:1.加大陣列的長度,2.增加hash函式的個數(並不是hash函式越多越好,要參考陣列的長度)。

hash錯誤率:(1)布隆演算法返回資料存在,則有可以資料實際不存在。(2)布隆演算法返回資料不存在,則資料一定不存在。

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

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

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

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

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

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