Redis緩存雪崩、緩存擊穿、緩存穿透詳解
1、緩存雪崩
【1】定義
大量緩存數(shù)據(jù)在同一時(shí)間失效,導(dǎo)致所有請求直接打到數(shù)據(jù)庫,引發(fā)數(shù)據(jù)庫瞬時(shí)高負(fù)載甚至崩潰
【2】原因
1、緩存數(shù)據(jù)設(shè)置了相同的過期時(shí)間
2、緩存服務(wù)宕機(jī)
【3】解決方案
[1]差異化過期時(shí)間
在基礎(chǔ)TTL上增加隨機(jī)值,避免同時(shí)失效
[2]多級緩存
結(jié)合本地緩存和分布式緩存,本地緩存失效后回源到分布式緩存
[3]熔斷降級
監(jiān)控?cái)?shù)據(jù)庫負(fù)載,超過閾值時(shí)觸發(fā)熔斷(如返回默認(rèn)值或限流)
[4]緩存永不過期+異步更新
緩存不設(shè)TTL,通過后臺任務(wù)定期更新(適合低頻變更數(shù)據(jù))
2、緩存擊穿
【1】定義
某個(gè)熱點(diǎn)key突然失效,大量并發(fā)請求直接穿透到數(shù)據(jù)庫,導(dǎo)致數(shù)據(jù)庫壓力激增
【2】原因
1、熱點(diǎn)key過期
2、惡意請求故意攻擊高頻訪問的key
【3】解決方案
[1]互斥鎖
第一個(gè)請求發(fā)現(xiàn)緩存失效時(shí),加鎖(如Redis SETNX),從數(shù)據(jù)庫加載數(shù)據(jù)后釋放鎖,其它請求等待或輪詢
[2]邏輯過期
1、緩存永不過期,但存儲數(shù)據(jù)時(shí)附加一個(gè)過期時(shí)間字段
2、發(fā)現(xiàn)數(shù)據(jù)邏輯過期時(shí),觸發(fā)異步更新
[3]熱點(diǎn)數(shù)據(jù)加載
監(jiān)控?zé)狳c(diǎn)key,在接近過期時(shí)提前刷新緩存
3、緩存穿透
【1】定義
查詢不存在的數(shù)據(jù)(如非法ID、惡意攻擊),導(dǎo)致請求繞過緩存直接訪問數(shù)據(jù)庫
【2】原因
1、業(yè)務(wù)邏輯漏洞(如未校驗(yàn)參數(shù)合法性)
2、惡意攻擊(如爬蟲偽造不存在的ID)
【3】解決方案
[1]緩存空對象
對查詢不到的數(shù)據(jù),混存一個(gè)空值,并設(shè)置較短TTL
[2]布隆過濾器
在緩存層前加布隆過濾器,快速判斷key是否存在:若布隆過濾器返回不存在,直接拒絕請求;若返回可能存在,繼續(xù)查詢緩存/數(shù)據(jù)庫
[3]參數(shù)校驗(yàn)
對請求參數(shù)做合法性校驗(yàn)
4、對比總結(jié)
問題 | 觸發(fā)條件 | 核心解決方案 |
---|---|---|
緩存雪崩 | 大量key同時(shí)失效 | 差異化TTL、多級緩存、熔斷降級 |
緩存擊穿 | 單個(gè)熱點(diǎn)key失效 | 互斥鎖、邏輯過期、預(yù)加載 |
緩存穿透 | 查詢不存在的數(shù)據(jù) | 布隆過濾器、控制緩存、參數(shù)校驗(yàn) |
5、最佳實(shí)踐
1、監(jiān)控與告警:實(shí)時(shí)監(jiān)控緩存命中率、數(shù)據(jù)庫QPS,設(shè)置閾值告警
2、壓測模擬:通過模擬雪崩/擊穿場景,驗(yàn)證解決方案的可靠性
3、組合策略:根據(jù)業(yè)務(wù)場景混合使用上述方案
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Redis Cluster集群動態(tài)擴(kuò)容的實(shí)現(xiàn)
本文主要介紹了Redis Cluster集群動態(tài)擴(kuò)容的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07Redis監(jiān)控工具RedisInsight安裝與使用
這篇文章主要為大家介紹了Redis監(jiān)控工具RedisInsight的安裝步驟與使用方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2022-03-03Windows系統(tǒng)安裝redis數(shù)據(jù)庫
這篇文章介紹了Windows系統(tǒng)安裝redis數(shù)據(jù)庫的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03Redis如何實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離詳解
Redis的主從架構(gòu),能幫助我們實(shí)現(xiàn)讀多,寫少的情況,下面這篇文章主要給大家介紹了關(guān)于Redis如何實(shí)現(xiàn)數(shù)據(jù)庫讀寫分離的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03Spring?Boot?整合Redis?實(shí)現(xiàn)優(yōu)惠卷秒殺?一人一單功能
這篇文章主要介紹了Spring?Boot?整合Redis?實(shí)現(xiàn)優(yōu)惠卷秒殺?一人一單,在分布式系統(tǒng)下,高并發(fā)的場景下,會出現(xiàn)此類庫存超賣問題,本篇文章介紹了采用樂觀鎖來解決,需要的朋友可以參考下2022-09-09