Redis中緩存穿透/擊穿/雪崩問題和解決方法
緩存問題
1. 緩存穿透---查不到
緩存穿透是指用戶想查詢一個數(shù)據(jù),發(fā)現(xiàn)Redis中沒有,也就是緩存沒有命中,就向持久性數(shù)據(jù)庫發(fā)起查詢,發(fā)現(xiàn)數(shù)據(jù)庫也沒有這個數(shù)據(jù),于是查詢失敗了。
當(dāng)用戶請求很多的情況下,緩存沒有命中,數(shù)據(jù)庫也沒有數(shù)據(jù),會給數(shù)據(jù)庫造成很大的壓力,這就是緩存穿透。
解決方案
第一種解決方案:使用布隆過濾器
使用布隆過濾器之后,將存儲的數(shù)據(jù)放入布隆過濾器中,每次數(shù)據(jù)查詢首先查詢布隆過濾器,當(dāng)在過濾器中判斷存在時,再到緩存查詢,如果沒有,再進(jìn)入數(shù)據(jù)查詢。
如果在布隆過濾器中不存在,則直接返回告訴用戶該數(shù)據(jù)查不到,這樣能大大減輕數(shù)據(jù)庫查詢壓力。
第二種方案:緩存空對象
當(dāng)數(shù)據(jù)庫數(shù)據(jù)不存在時,將返回的空對象緩存起來,同時設(shè)置一個過期時間,之后在訪問數(shù)據(jù)時,將從緩存中獲取,從而保護(hù)了數(shù)據(jù)庫。
存在問題:
對空值設(shè)置過期時間,會存在更新數(shù)據(jù)庫數(shù)據(jù)到緩存數(shù)據(jù)失效的這一段時間,緩存數(shù)據(jù)有問題(問題在于緩存的空對象數(shù)據(jù),由于還沒有過期,但此時數(shù)據(jù)庫數(shù)據(jù)已經(jīng)更新了),會對要保證數(shù)據(jù)一致性的業(yè)務(wù)造成影響。會需要更多的空間來存儲更多的控制,造成內(nèi)存中有大量的空值的鍵。
2. 緩存擊穿---量太大,緩存過期
緩存擊穿是指一個熱點(diǎn)key,在不停的扛著大量的并發(fā),當(dāng)key在失效的瞬間,持續(xù)的大并發(fā)就會穿破緩存,直接請求到數(shù)據(jù)庫。對數(shù)據(jù)庫造成瞬間壓力過大。
解決方案
第一種方案:熱點(diǎn)數(shù)據(jù)永不過期
從緩存角度看,沒有設(shè)置過期時間,就不會存在緩存過期之后產(chǎn)生的問題。
第二種方案:加互斥鎖
使用分布式鎖,保證對每個key的訪問同一時刻只能一個線程去查詢后端服務(wù),其他沒有獲取鎖權(quán)限的線程則等待即可。
3. 緩存雪崩
緩存雪崩是指在某一個時間段,緩存集中過期失效或者Redis宕機(jī)
對于數(shù)據(jù)庫而言,所有請求壓力會全部到達(dá)數(shù)據(jù)庫,導(dǎo)致數(shù)據(jù)庫調(diào)用量暴增,可能也造成數(shù)據(jù)庫宕機(jī)的情況
解決方案
第一種方案(預(yù)防為主):Redis采用高可用
這種方案的思路就是集群使用,即使一個redis掛掉,其他redis還可以繼續(xù)服務(wù)。
第二種方案(降低發(fā)生時所造成的危害):限流降級
這種思路就是在緩存失效后,通過加鎖或者隊(duì)列來控制讀取數(shù)據(jù)庫的線程數(shù)量讓線程在隊(duì)列排隊(duì),控制整體請請求速率。
第三種方案:數(shù)據(jù)預(yù)熱
數(shù)據(jù)預(yù)熱即是在正式部署服務(wù)之前,先訪問一遍數(shù)據(jù),可以將大部分的數(shù)據(jù)加載到緩存中,在即將發(fā)生大并發(fā)之前已經(jīng)加載不同的key,設(shè)置不同的過期時間,讓緩存失效的時間更加均勻。
到此這篇關(guān)于Redis中緩存穿透/擊穿/雪崩問題和解決方法的文章就介紹到這了,更多相關(guān)Redis緩存穿透/擊穿/雪崩問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis整合SpringBoot的RedisTemplate實(shí)現(xiàn)類(實(shí)例詳解)
這篇文章主要介紹了Redis整合SpringBoot的RedisTemplate實(shí)現(xiàn)類,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01Redis實(shí)現(xiàn)分布式鎖的實(shí)例講解
在本篇文章里小編給大家整理了一篇關(guān)于Redis實(shí)現(xiàn)分布式鎖的實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。2021-12-12Redis在項(xiàng)目中常見的12種使用場景示例和說明
Redis是一個開源的高性能鍵值對數(shù)據(jù)庫,它以其內(nèi)存中數(shù)據(jù)存儲、鍵過期策略、持久化、事務(wù)、豐富的數(shù)據(jù)類型支持以及原子操作等特性,在許多項(xiàng)目中扮演著關(guān)鍵角色,以下是整理的12個Redis在項(xiàng)目中常見的使用場景舉例說明和解釋2024-06-06如何操作Redis和zookeeper實(shí)現(xiàn)分布式鎖
這篇文章主要介紹了如何操作Redis和zookeeper實(shí)現(xiàn)分布式鎖的相關(guān)資料,需要的朋友可以參考下2017-07-07redis安裝和配置_動力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了redis安裝和配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08- Redis緩沖區(qū)溢出是指Redis緩沖區(qū)被寫入的數(shù)據(jù)超過了它的容量,導(dǎo)致數(shù)據(jù)無法存儲或被覆蓋。造成緩沖區(qū)溢出的原因可能是快速寫入大量數(shù)據(jù)、緩沖區(qū)未及時刷新或Redis服務(wù)器配置不當(dāng)?shù)取?/div> 2023-04-04
Redis報(bào)錯UnrecognizedPropertyException: Unrecognized 
在使用SpringBoot訪問Redis時,報(bào)錯提示識別不了屬性headPart,經(jīng)過排查,發(fā)現(xiàn)并非Serializable或getset方法問題,而是存在一個方法getHeadPart,但無headPart屬性,解決方案是將getHeadPart改為makeHeadPart2024-10-10最新評論