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

2021-09-19 12:54:47 字數 408 閱讀 8742

訪問乙個不存在的key,快取不起作用,請求會穿透到db,流量大時db會掛掉。

採用布隆過濾器,使用乙個足夠大的bitmap,用於儲存可能訪問的key,不存在的key直接被過濾;

訪問key未在db查詢到值,也將空值寫進快取,但可以設定較短過期時間。

大量的key設定了相同的過期時間,導致在快取在同一時刻全部失效,造成瞬時db請求量大、壓力驟增,引起雪崩。

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

乙個存在的key,在快取過期的一刻,同時有大量的請求,這些請求都會擊穿到db,造成瞬時db請求量大、壓力驟增。

在訪問key之前,採用setnx(set if not exists)來設定另乙個短期key來鎖住當前key的訪問,訪問結束再刪除該短期key。

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

訪問乙個不存在的key,快取不起作用,請求會穿透到db,流量大時db會掛掉。採用布隆過濾器,使用乙個足夠大的bitmap,用於儲存可能訪問的key,不存在的key直接被過濾 訪問key未在db查詢到值,也將空值寫進快取,但可以設定較短過期時間。大量的key設定了相同的過期時間,導致在快取在同一時刻全...

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

訪問乙個不存在的key,快取不起作用,請求會穿透到db,流量大時db會掛掉。採用布隆過濾器,使用乙個足夠大的bitmap,用於儲存可能訪問的key,不存在的key直接被過濾 訪問key未在db查詢到值,也將空值寫進快取,但可以設定較短過期時間。大量的key設定了相同的過期時間,導致在快取在同一時刻全...

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

訪問乙個不存在的key,快取不起作用,請求會穿透到db,流量大時db會掛掉。採用布隆過濾器,使用乙個足夠大的bitmap,用於儲存可能訪問的key,不存在的key直接被過濾 訪問key未在db查詢到值,也將空值寫進快取,但可以設定較短過期時間。大量的key設定了相同的過期時間,導致在快取在同一時刻全...