Redis 緩存穿透、擊穿、雪崩是一些常見(jiàn)的緩存問(wèn)題,下面簡(jiǎn)要介紹一下:
1. 緩存穿透
緩存穿透是指無(wú)論是新數(shù)據(jù)還是舊數(shù)據(jù),都無(wú)法在緩存中找到對(duì)應(yīng)的值,從而導(dǎo)致請(qǐng)求一直訪問(wèn)后端數(shù)據(jù)庫(kù)。造成緩存穿透的原因通常是惡意攻擊或者緩存中沒(méi)有需要的值。
解決方案:
- 緩存空值,即使請(qǐng)求一個(gè)不存在的鍵也將空值存儲(chǔ)在緩存中,以后的請(qǐng)求就可以直接從緩存中獲取空值,降低對(duì)后端數(shù)據(jù)庫(kù)的壓力。
- 布隆過(guò)濾器,先判斷請(qǐng)求的鍵是否存在于緩存中,不存在就直接返回空值。
2. 緩存擊穿
緩存擊穿是指緩存中沒(méi)有但數(shù)據(jù)庫(kù)中存在的數(shù)據(jù),在高并發(fā)情況下,突然有大量的請(qǐng)求訪問(wèn)這些不存在的數(shù)據(jù),導(dǎo)致數(shù)據(jù)庫(kù)壓力過(guò)大。
解決方案:
- 加鎖,對(duì)緩存空失效的情況進(jìn)行加鎖,只有一次性地從數(shù)據(jù)庫(kù)加載數(shù)據(jù)并更新緩存中的鍵才能夠解鎖。
- 提前預(yù)加載,提前在緩存中加載一些熱門(mén)的數(shù)據(jù),避免突然緩存穿透導(dǎo)致大量請(qǐng)求同時(shí)訪問(wèn)數(shù)據(jù)庫(kù)。
3. 緩存雪崩
緩存雪崩是指大量的緩存數(shù)據(jù)在同一時(shí)間失效,導(dǎo)致大量的請(qǐng)求直接打到數(shù)據(jù)庫(kù)上,導(dǎo)致數(shù)據(jù)庫(kù)崩潰。
解決方案:
- 緩存失效時(shí)間分散,通過(guò)在緩存中設(shè)置過(guò)期時(shí)間的隨機(jī)性來(lái)分散緩存的失效時(shí)間,避免大量緩存同時(shí)失效。
- 限流降級(jí),設(shè)置系統(tǒng)限流,對(duì)請(qǐng)求進(jìn)行限制,減小緩存雪崩的概率。
- 雙緩存策略,使用兩級(jí)緩存結(jié)構(gòu),將請(qǐng)求分配到兩個(gè)不同的緩存中,當(dāng)一個(gè)緩存失效時(shí),另一個(gè)緩存可以繼續(xù)提供服務(wù)。