成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Redis 擊穿、穿透、雪崩產(chǎn)生原因以及解決思路

數(shù)據(jù)庫 Redis
為了解決內(nèi)存與磁盤速度不匹配的問題,產(chǎn)生了緩存,將一些熱點數(shù)據(jù)放在內(nèi)存中,隨用隨取,降低連接到數(shù)據(jù)庫的請求鏈接,避免數(shù)據(jù)庫掛掉。

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

問題起因

有兩個主要原因:

  • Key過期;
  • Key被頁面置換淘汰。

對于第一個原因是因為在Redis中,Key有過期時間,如果某一個時刻(假如商城做活動,零點開始)key失效,那么零點之后對某一個商品查詢請求將全都壓到數(shù)據(jù)庫上,導致數(shù)據(jù)庫崩。

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

應對擊穿的處理思路

正常的處理請求如圖:

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

這個流程大概如下:

  • 請求到達Redis,發(fā)現(xiàn)Redis Key過期,查看有沒有鎖,沒有鎖的話回到隊列后面排隊
  • 設(shè)置鎖,注意,這兒應該是setnx(),而不是set(),因為可能有其他線程已經(jīng)設(shè)置鎖了
  • 獲取鎖,拿到鎖了就去數(shù)據(jù)庫取數(shù)據(jù),請求返回后釋放鎖。

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

對鎖設(shè)置一個過期時間,如果到達了過期時間還沒釋放就自動釋放,問題又來了,鎖掛了好說,但是如果是鎖超時呢?也就是在設(shè)定的時間里數(shù)據(jù)沒有取出來,但是鎖由過期了,常見的思路是,鎖過期時間值遞增,但是想想不靠譜,因為第一個請求可能超時,如果后面的也超時呢,接連多次超時之后,鎖過期時間值勢必特別大了,這樣做弊端太多。

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

穿透

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

應對這種請求,處理辦法是對訪問請求加一層過濾器,例如布隆過濾器、增強版布隆過濾器、布谷鳥過濾器。

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

雪崩

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

明顯不可以,同樣存錢,你存到年底利息300萬,隔壁才200萬,這不得打架啊,開玩笑。

正確的思路是,首先要看看這個Key過期是不是時點性有關(guān),時點性無關(guān)的話,可以隨機過期時間解決。

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

在后臺更新熱點key的同時,業(yè)務層將進來的請求延時一下,例如短暫的睡幾毫秒或者秒,給后面的更新熱點key分散壓力。

責任編輯:趙寧寧 來源: 技術(shù)老男孩
相關(guān)推薦

2020-03-16 14:57:24

Redis面試雪崩

2023-03-10 13:33:00

緩存穿透緩存擊穿緩存雪崩

2019-10-12 14:19:05

Redis數(shù)據(jù)庫緩存

2022-03-08 00:07:51

緩存雪崩數(shù)據(jù)庫

2022-11-18 14:34:28

2021-06-05 09:01:01

Redis緩存雪崩緩存穿透

2024-04-07 00:00:02

Redis雪崩緩存

2024-04-18 11:43:28

緩存數(shù)據(jù)庫Redis

2020-03-05 09:09:18

緩存原因方案

2023-11-10 14:58:03

2019-11-05 14:24:31

緩存雪崩框架

2020-10-23 10:46:03

緩存雪崩擊穿

2023-12-06 13:38:00

Redis緩存穿透緩存擊穿

2023-04-14 07:34:19

2020-09-14 06:57:30

緩存穿透雪崩

2022-05-27 07:57:20

緩存穿透緩存雪崩緩存擊穿

2023-10-13 08:11:22

2025-05-28 02:25:00

高并發(fā)緩存穿透雪崩

2023-01-31 08:37:11

緩存穿透擊穿

2018-11-12 11:12:46

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日韩久久久久久 | 99精品99| 一级毛片免费看 | 欧美久久一区二区三区 | 国产欧美日韩综合精品一区二区 | 亚洲一页 | 亚洲va欧美va天堂v国产综合 | 国产午夜精品久久久久 | 一级在线毛片 | 国产精品无码专区在线观看 | 99精品欧美一区二区三区 | 成人精品一区二区三区中文字幕 | 一区二区三区四区电影 | 成人在线视频一区 | 神马影院一区二区三区 | www日本在线播放 | 午夜欧美一区二区三区在线播放 | 日韩精品一区二区不卡 | 亚洲免费在线视频 | 欧美日韩黄色一级片 | 色黄视频在线 | 三级视频在线观看电影 | 成人黄色电影在线播放 | 亚洲一区 | 性国产xxxx乳高跟 | 亚洲免费在线 | 日本超碰 | 81精品国产乱码久久久久久 | 午夜视频在线 | 99精品亚洲国产精品久久不卡 | 国产日韩免费观看 | 日本a在线| 成人在线视频免费观看 | 国产精品久久久久久久久免费高清 | 黄色一级片在线播放 | 特级黄一级播放 | 亚洲毛片在线观看 | 天天干视频 | 亚洲人成人一区二区在线观看 | 9久久精品 | 精品av|