欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis擊穿穿透雪崩產(chǎn)生原因分析及解決思路面試

 更新時(shí)間:2022年03月09日 10:14:52   作者:Q.E.D  
這篇文章主要為大家介紹了Redis擊穿穿透雪崩產(chǎn)生原因及解決思路的面試問(wèn)題答案參考,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進(jìn)步

1、前言

大家都知道,計(jì)算機(jī)的瓶頸之一就是IO,為了解決內(nèi)存與磁盤速度不匹配的問(wèn)題,產(chǎn)生了緩存,將一些熱點(diǎn)數(shù)據(jù)放在內(nèi)存中,隨用隨取,降低連接到數(shù)據(jù)庫(kù)的請(qǐng)求鏈接,避免數(shù)據(jù)庫(kù)掛掉。需要注意的是,無(wú)論是擊穿還是后面談到的穿透與雪崩,都是在高并發(fā)前提下,比如當(dāng)緩存中某一個(gè)熱點(diǎn)key失效。

圖片

2、問(wèn)題起因 

有兩個(gè)主要原因:

  • 1、Key過(guò)期;
  • 2、Key被頁(yè)面置換淘汰。

對(duì)于第一個(gè)原因是因?yàn)樵赗edis中,Key有過(guò)期時(shí)間,如果某一個(gè)時(shí)刻(假如商城做活動(dòng),零點(diǎn)開始)key失效,那么零點(diǎn)之后對(duì)某一個(gè)商品查詢請(qǐng)求將全都?jí)旱綌?shù)據(jù)庫(kù)上,導(dǎo)致數(shù)據(jù)庫(kù)崩。

對(duì)于第二個(gè)原因,因?yàn)閮?nèi)存是有限的,要時(shí)時(shí)刻刻緩存新的數(shù)據(jù),淘汰舊的數(shù)據(jù),所以在一定的頁(yè)面置換策略(常見頁(yè)面置換算法圖解)中,淘汰數(shù)據(jù),如果某些商品做活動(dòng)之前無(wú)人問(wèn)津,勢(shì)必會(huì)被淘汰。

3、應(yīng)對(duì)擊穿的處理思路

正常的處理請(qǐng)求如圖:

圖片

由于key過(guò)期在所難免,高流量來(lái)到Redis時(shí),根據(jù)Redis的單線程特性,可以認(rèn)為任務(wù)是在隊(duì)列里依次執(zhí)行的,當(dāng)請(qǐng)求到達(dá)Redis發(fā)現(xiàn)Key過(guò)期時(shí),進(jìn)行一個(gè)操作:設(shè)置鎖。

這個(gè)流程大概如下:

  • 請(qǐng)求到達(dá)Redis,發(fā)現(xiàn)Redis Key過(guò)期,查看有沒有鎖,沒有鎖的話回到隊(duì)列后面排隊(duì)
  • 設(shè)置鎖,注意,這兒應(yīng)該是setnx(),而不是set(),因?yàn)榭赡苡衅渌€程已經(jīng)設(shè)置鎖了
  • 獲取鎖,拿到鎖了就去數(shù)據(jù)庫(kù)取數(shù)據(jù),請(qǐng)求返回后釋放鎖。

圖片

 但是引出了一個(gè)新的問(wèn)題,如果拿到鎖去拿數(shù)據(jù)的請(qǐng)求然后掛了怎么辦?也就是鎖沒有釋放,其他進(jìn)程都在等鎖,解決辦法是:

對(duì)鎖設(shè)置一個(gè)過(guò)期時(shí)間,如果到達(dá)了過(guò)期時(shí)間還沒釋放就自動(dòng)釋放,問(wèn)題又來(lái)了,鎖掛了好說(shuō),但是如果是鎖超時(shí)呢?也就是在設(shè)定的時(shí)間里數(shù)據(jù)沒有取出來(lái),但是鎖由過(guò)期了,常見的思路是,鎖過(guò)期時(shí)間值遞增,但是想想不靠譜,因?yàn)榈谝粋€(gè)請(qǐng)求可能超時(shí),如果后面的也超時(shí)呢,接連多次超時(shí)之后,鎖過(guò)期時(shí)間值勢(shì)必特別大了,這樣做弊端太多。

另外一個(gè)思路是,再開啟一個(gè)線程,進(jìn)行監(jiān)控,如果取數(shù)據(jù)的線程沒有掛的話,就適當(dāng)延遲鎖的過(guò)期時(shí)間。

圖片

4、穿透 

穿透主要原因是很多請(qǐng)求都在訪問(wèn)數(shù)據(jù)庫(kù)不存在的數(shù)據(jù),例如一個(gè)賣書的商城一直被請(qǐng)求查詢茶葉產(chǎn)品,由于Redis緩存主要是用來(lái)緩存熱點(diǎn)數(shù)據(jù),對(duì)于數(shù)據(jù)庫(kù)都不存在的數(shù)據(jù),是沒法緩存的,這種異常流量就會(huì)直接到達(dá)數(shù)據(jù)庫(kù)并且返回"沒有"的查詢結(jié)果。

應(yīng)對(duì)這種請(qǐng)求,處理辦法是對(duì)訪問(wèn)請(qǐng)求加一層過(guò)濾器,例如布隆過(guò)濾器、增強(qiáng)版布隆過(guò)濾器、布谷鳥過(guò)濾器。

圖片

除了布隆過(guò)濾器,可以增加一些參數(shù)檢驗(yàn),例如數(shù)據(jù)庫(kù)數(shù)據(jù)id一般都是遞增的,如果請(qǐng)求 id = -10 這種參數(shù),勢(shì)必繞過(guò)Redis,避免這種情況,可以對(duì)用戶真實(shí)性檢驗(yàn)等操作。

5、雪崩 

雪崩,和擊穿類似,不同的是擊穿是一個(gè)熱點(diǎn)Key某時(shí)刻失效,而雪崩是大量的熱點(diǎn)Key在一瞬間失效,網(wǎng)絡(luò)上很多博客都在強(qiáng)調(diào)解決雪崩的策略是隨機(jī)過(guò)期時(shí)間,這個(gè)非常不準(zhǔn)確,舉個(gè)例子,銀行做活動(dòng),之前這個(gè)利息系數(shù)為2%,過(guò)了零點(diǎn)系數(shù)改為3%,這種情況能將用戶的對(duì)應(yīng)的key改為隨機(jī)過(guò)期嗎?如果用的過(guò)去的數(shù)據(jù)叫臟數(shù)據(jù)。

明顯不可以,同樣存錢f0c;你存到年底利息300萬(wàn),隔壁才200萬(wàn),這不得打架啊,開玩笑~

正確的思路是,首先要看看這個(gè)Key過(guò)期是不是時(shí)點(diǎn)性有關(guān),時(shí)點(diǎn)性無(wú)關(guān)的話,可以隨機(jī)過(guò)期時(shí)間解決。

如果是時(shí)點(diǎn)性有關(guān),例如剛剛說(shuō)的銀行某一天改變某系數(shù),那么就要利用強(qiáng)依賴擊穿方案,策略是先過(guò)去的線程更新一下所有key。

圖片

在后臺(tái)更新熱點(diǎn)key的同時(shí),業(yè)務(wù)層將進(jìn)來(lái)的請(qǐng)求延時(shí)一下,例如短暫的睡幾毫秒或者秒,給后面的更新熱點(diǎn)key分散壓力。

結(jié)束

以上就是Redis擊穿穿透雪崩產(chǎn)生原因及解決思路面試的詳細(xì)內(nèi)容,更多關(guān)于Redis擊穿穿透雪崩解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • redis中key使用冒號(hào)分隔的原理小結(jié)

    redis中key使用冒號(hào)分隔的原理小結(jié)

    Redis是一種高性能的鍵值對(duì)非關(guān)系型數(shù)據(jù)庫(kù),通過(guò)redis不同類型命令可以為其中的鍵指定不同的數(shù)據(jù)類型,其中每個(gè)鍵的命名規(guī)范通常使用冒號(hào)符號(hào)分隔字符串,本文主要介紹了redis中key使用冒號(hào)分隔的原理小結(jié),感興趣的可以了解一下
    2024-01-01
  • redis如何設(shè)置key的有效期

    redis如何設(shè)置key的有效期

    這篇文章主要介紹了redis如何設(shè)置key的有效期方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • Redis分布式鎖升級(jí)版RedLock及SpringBoot實(shí)現(xiàn)方法

    Redis分布式鎖升級(jí)版RedLock及SpringBoot實(shí)現(xiàn)方法

    這篇文章主要介紹了Redis分布式鎖升級(jí)版RedLock及SpringBoot實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • 高并發(fā)下Redis如何保持?jǐn)?shù)據(jù)一致性(避免讀后寫)

    高并發(fā)下Redis如何保持?jǐn)?shù)據(jù)一致性(避免讀后寫)

    本文主要介紹了高并發(fā)下Redis如何保持?jǐn)?shù)據(jù)一致性(避免讀后寫),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Redis服務(wù)器的啟動(dòng)過(guò)程分析

    Redis服務(wù)器的啟動(dòng)過(guò)程分析

    這篇文章主要介紹了Redis服務(wù)器的啟動(dòng)過(guò)程分析,本文講解了初始化Redis服務(wù)器全局配置、加載配置文件、初始化服務(wù)器、加載數(shù)據(jù)、開始網(wǎng)絡(luò)監(jiān)聽等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • Redis?Lua腳本實(shí)現(xiàn)ip限流示例

    Redis?Lua腳本實(shí)現(xiàn)ip限流示例

    這篇文章主要介紹了Redis?Lua腳本實(shí)現(xiàn)ip限流示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 詳解redis desktop manager安裝及連接方式

    詳解redis desktop manager安裝及連接方式

    這篇文章主要介紹了redis desktop manager安裝及連接方式,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Redis全量同步和增量同步原理

    Redis全量同步和增量同步原理

    主從第一次同步是全量同步:也就是說(shuō),當(dāng)你主從節(jié)點(diǎn)連接建立后,需要執(zhí)行一次全量同步,但如果slave重啟后同步,此時(shí)slave重啟后,slave節(jié)點(diǎn)和master節(jié)點(diǎn)的數(shù)據(jù)之間有落后,因此需要進(jìn)行增量同步,感興趣的同學(xué)可以參考閱讀
    2023-04-04
  • 關(guān)于分布式鎖的三種實(shí)現(xiàn)方式

    關(guān)于分布式鎖的三種實(shí)現(xiàn)方式

    這篇文章主要介紹了關(guān)于分布式鎖的三種實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Redis實(shí)現(xiàn)庫(kù)存扣減的解決方案防止商品超賣

    Redis實(shí)現(xiàn)庫(kù)存扣減的解決方案防止商品超賣

    在日常開發(fā)中有很多地方都有類似扣減庫(kù)存的操作,比如電商系統(tǒng)中的商品庫(kù)存,抽獎(jiǎng)系統(tǒng)中的獎(jiǎng)品庫(kù)存等,基于redis實(shí)現(xiàn)扣減庫(kù)存的具體實(shí)現(xiàn),初始化庫(kù)存回調(diào)函數(shù)(IStockCallback)扣減庫(kù)存服務(wù)(StockService),感興趣的朋友跟隨小編一起看看吧
    2022-06-06

最新評(píng)論