国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

老生常談的Redis雪崩、擊穿、穿透、預熱、降級一次全安排

數據庫 其他數據庫 Redis
今天我們就重點看企業中在使用 Redis 常見一些問題以及對應解決方案。

 [[392445]]

關于 Redis 的介紹、特點什么的就不再這里贅述了,不然又要水千把字。今天我們就重點看企業中在使用 Redis 常見一些問題以及對應解決方案。

某個請求到達業務系統,想要獲取某個數據,一般是先從緩存中獲取,如果緩存中不存在就會去數據庫中查詢,如果查詢到結果就將數據保存到緩存中再返回結果。

一個新的技術的引進,必然會帶來一些額外的問題,那么 Redis 這么優秀的 NoSQL 數據庫會帶來什么樣的問題呢?我們一起拭目以待。

緩存擊穿

緩存擊穿根據名字根本無法看懂是什么意思,并且很容易和另一個詞——緩存穿透搞混。緩存擊穿指的是某個 key 一直在扛著高并發,所謂扛著高并發就是說大量的請求都是獲取這個 key 對應的值。

而這個 key 在某個時間突然失效了,那是不是就意味著大量的請求就無法在緩存中獲取數據了,而是去請求數據庫了,這樣很有可能導致數據庫被擊垮。這就是緩存擊穿。

那現在問題知道了,該如何應對呢?這個就比較簡單了,既然這個 key 這個受歡迎,那么就不要設置過期時間了,如果該key的數據更新了,那么就通過互斥鎖的方式將其更新。

為什么要用互斥鎖的方式?如果不使用互斥鎖的方式很容易導致數據不一致的情況,這里為了保證緩存和數據庫的一致性,就只能犧牲一點點的效率了。

緩存雪崩

不知道各位小伙伴都是來自哪里,我們那邊有句方言叫“雪崩”,表示事情砸了的意思。這里的Redis 雪崩似乎有點異曲同工之妙。首先我們需要知道什么是 Redis雪崩,

Redis雪崩我們一般都稱為緩存雪崩,意思就是說在某個時間節點,大量的 key 失效,導致大量的請求從緩存中獲取不到數據而去請求數據庫。根據上面的那張圖,我們再來畫下雪崩的情況的是什么樣子的:

上面的黑色的部分表示緩存無效了,也就意味著所有的請求都需要到數據庫中去查詢數據。那這對于數據庫的壓力必然是劇增的,如果是在一線互聯網這樣超高并發的場景下,數據庫直接宕機。

重啟也沒有用,因為重啟了還會有巨大的流量涌進來,然后繼續被搞宕機。所以對于預防緩存雪崩這種情況的發生意義還是很大的的。

緩存雪崩解決方案之加隨機值

上面已經詳細介紹了什么是緩存雪崩,他是怎么發生的,那如果防止緩存雪崩呢?

很簡單,因為上面剛剛說到,緩存雪崩是由于某個時間節點大量的 key 失效而導致的問題,那現在的問題不就是變成了如何防止同一個時間節點大量的 key 失效這種情況發生嗎?

最簡單的情況就是把key的過期時間分散開,也就是在設置key的過期時間的時候再加一個隨機值,就這樣就能完美的解決緩存雪崩的問題。

但是你以為我說到這里就完事了?既然是一次全安排,那么我一定不會僅僅告訴你一種解決方案就完事的。繼續看

緩存雪崩解決方案之加鎖

可能很多人看到這個方案表示不接受,加鎖那不是限制了并發?加鎖必然導致阻塞。如果是加鎖,那么執行就成就是這個樣子了:

流程是這樣子的,在多個請求同時到達業務系統時候,只能有一個線程能獲取到鎖,然后才能繼續去緩存或者是數據庫中查詢數據,然后后面的流程和之前的是一樣的,執行完成后釋放鎖,然后其他線程再爭搶鎖,然后重復前面的流程。

這個方案的優點是可以很好的保護數據庫不會被打掛,缺點就是并發度極低。

上面這個方案其實還是可以再優化下的:

這個就是在緩存中如果獲取不到,再去串行的訪問數據看,這里不一定非要串行,可以配合線程池,控制一定的并發數。

這個缺點雖然很多,但是也是一種解決方案。用不用就看實際的業務場景了。畢竟沒有沒用技術方案,只有不適合業務場景的技術方案(手動狗頭)。

緩存穿透

緩存穿透意思就是某個不存在的key一直被訪問,結果發現數據庫中也沒有這樣的數據,最終導致訪問該key的所有請求都直接請求到數據庫了。如果是并發高的場景下就容易搞垮數據庫。大家有沒有發現我們做的一些事情都是在保護“弱小的數據庫”。

那現在問題已經知道了,我們該如何去解決這個問題呢?

緩存穿透解決方案之緩存空數據

啥叫緩存空數據?就是假設某個key數據并不存在,那么就存一個 NULL 就好了,但是一定不要忘記設置過期時間,因為假設id=3的記錄不存在,然后本次訪問沒有查詢到數據,緩存中存的是null如果過一會兒新增了一條記錄為3的數據,如果緩存不設置過期時間,那么這條數據就永遠獲取不到。

緩存穿透解決方案之布隆過濾器

布隆過濾器?這玩意到底什么意思?

布隆過濾器是一種數據結構,更準確的說是一種概率型的數據結構,因為它能判斷某個元素一定不存在或者是可能存在。

就這句話,搞蒙了很多人,今天我非要把你說明白了。布隆過濾器是一個bit數組,一個很長的bit數組和一系列的hash函數構成。先看下圖

我們現在來舉個例子,假設現在有小強和旺財兩個人,他們分別經過三次hash得到的下標是這樣子的(布隆過濾器不存儲元素,僅僅是為一個元素是否存在打一個標志)

小強經過上面的三個hash后得到的下標分別為:2、4、5,那么該數組的2、4、5位置就會被置為1,也就是此時是這樣子的

同樣旺財經過上面的三個hash后得到的下標分別為:3、7、11,那么該數組的3、7、11位置就會被置為1,也就是此時是這樣子的

現在假設來一個 007 經過上面的三個hash后得到的下標分別為:11、13、15因為13、和15位置是0,所以一定可以判斷007 一定不存在。但是現在又來了一個

9527經過上面的三個hash后得到的下標分別為:2、5、7,但是你會發現257三個位置全部是1,那這個到底說明9527是存在還是不存在呢?

從我們上面的講解可以 9527 之前并不存在,但是由于hash沖突,但是9527的三個下標值也剛好落在已經被置為1的下標位置,這就導致此時是無法判斷9527是否存在的。這就是布隆過濾器的原理。

要不來段代碼壓壓驚?

我們來使用 google 包下的類來測試。首先要添加依賴 

  1. <dependency>  
  2.     <groupId>com.google.guava</groupId>  
  3.     <artifactId>guava</artifactId>  
  4.     <version>30.1-jre</version>  
  5. </dependency> 

代碼如下(詳細的解釋我已經寫在注釋中了,這個是可以用于實際生產的代碼) 

  1. public class BloomFilterDemo {  
  2.     public static void main(String[] args) {  
  3.         /**  
  4.          * 創建一個插入對象為一億,誤報率為0.01%的布隆過濾器  
  5.          * 不存在一定不存在  
  6.          * 存在不一定存在  
  7.          */ 
  8.          BloomFilter&lt;CharSequence&gt; bloomFilter = BloomFilter.create(Funnels.stringFunnel(Charset.forName("utf-8")),  
  9.                 100000000,  
  10.                 0.0001);  
  11.         bloomFilter.put("死");  
  12.         bloomFilter.put("磕");  
  13.         bloomFilter.put("Redis");  
  14.         System.out.println(bloomFilter.mightContain("Redis"));  
  15.         System.out.println(bloomFilter.mightContain("死"));  
  16.         System.out.println(bloomFilter.mightContain("磕"));  
  17.         System.out.println(bloomFilter.mightContain("Java"));  
  18.     }  

結果

完。

等等……緩存穿透、預熱、降級你還沒說呢。哦,我真的以為本文結束了。

那布隆過濾器是如何解決緩存穿透的問題的呢?既然已經知道了布隆過濾器的原理,那么就可以通過布隆過濾器來快速的判斷出一個key是否存在數據庫中,如果可能存在再去數據庫查詢,如果布隆過濾器中不存在那么就需要再去數據庫查詢了。

緩存預熱

這又是什么鬼?怎么搞一個緩存還有這么多問題,那還要緩存干啥?

所謂緩存預熱就是將一些可能經常使用數據在系統啟動的時候預先設置到緩存中,這樣可以避免在使用到的時候先去數據庫中查詢。

這就是緩存預熱,名氣高大上,實際上很簡單有木有,這個緩存預熱我在實際場景是經常使用的。

還有一種方式就是添加一個緩存刷新頁,這樣通過人工干預的方式將一些可能為熱點的key添加到緩存中。

緩存降級

當訪問量突然劇增(例如下班的點,大家都在地鐵上刷手機呢)、服務出現問題(如響應時間慢或不響應)或非核心服務影響到核心流程的性能時,仍然需要保證服務還是可用的,即使是有損服務。

系統可以根據一些關鍵數據進行自動降級,降級的最終目的是保證核心服務可用,即使是有損的。但是有的一些業務的核心服務是不能降級的。這是一種丟卒保帥的思想。

結束語

關于技術的學習,大家除了為了應付面試去短期強行的記憶一些知識點外,我還是建議各位在學習階段能夠循序漸進。小孩子從出生到走路一般還有10個月呢,要想會說話時間就更長。

但是這個過程必須是有的,因為小孩子需要一點一點來適應這個未知的世界。我們作為成年人在學習的時候也要保持這種平靜心態,有些事情急是沒用的。

最后以一句不畏艱險,勇攀高峰來和大家共勉。 

 

責任編輯:龐桂玉 來源: Hollis
相關推薦

2021-04-12 09:36:25

Redis擊穿穿透

2024-04-07 00:00:02

Redis雪崩緩存

2020-03-16 14:57:24

Redis面試雪崩

2015-06-25 10:46:23

數據中心節能

2015-07-21 13:39:58

Javascript作用域

2015-04-08 11:50:07

數據加密數據泄露

2019-10-12 14:19:05

Redis數據庫緩存

2023-03-10 13:33:00

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

2022-03-08 15:01:48

負載均衡IP服務器

2014-07-25 13:34:08

2014-08-21 10:25:44

網絡安全兒童賬戶Google

2010-07-28 09:09:55

SQL

2011-08-18 14:47:06

2012-02-13 09:46:56

數據中心耗能服務器虛擬化

2023-04-14 07:34:19

2024-04-18 11:43:28

緩存數據庫Redis

2022-11-18 14:34:28

2024-01-19 20:42:08

Redis數據庫Key

2021-06-05 09:01:01

Redis緩存雪崩緩存穿透

2022-03-08 00:07:51

緩存雪崩數據庫
點贊
收藏

51CTO技術棧公眾號

黄色av成人| 免费成人高清在线视频| 香蕉人人精品| 欧美va亚洲va| 羞羞小视频视频| 蜜桃视频一区二区三区在线观看| 俺去啦;欧美日韩| 日本成a人片在线观看| 亚洲欧洲日韩av| 国产精品久久久久9999爆乳| 欧美阿v一级看视频| 久久视频免费观看| 国产美女视频一区二区三区 | 爱爱爱免费视频在线观看| 91日韩一区二区三区| 91精品久久久久久久久久| 黄色的网站在线观看| 亚洲五月综合| 久久精品72免费观看| 欧美在线一区二区视频| 我爱我色成人网| 欧美高清一级片在线| 欧美h版电影| 国产亚洲欧洲997久久综合| 亚洲永久激情精品| 国产精品入口| 成人亚洲欧美一区二区三区| 亚洲最好看的视频| 欧美区二区三区| 久久精品资源| 色噜噜亚洲精品中文字幕| 2021中文字幕在线| 国产一二三四五| 蜜桃免费网站一区二区三区| 99r国产精品| 一区二区精品在线| 另类av一区二区| 久久精精品视频| 在线日韩中文| 久久爱av电影| 日韩一级片一区二区| 亚洲丝袜一区| 日韩女优av电影| av片在线观看永久免费| 69p69国产精品| 成人av黄色| 亚洲精品suv精品一区二区| 毛片在线网站| 国产亚洲日本欧美韩国| 成人一区视频| 另类少妇人与禽zozz0性伦| 亚洲视频资源| 久久久女女女女999久久| 亚洲v天堂v手机在线| 国产精品成人品| 女生裸体视频一区二区三区| 国产精品日韩一区二区三区| 日韩和欧美一区二区| 特级西西444| 久久久www成人免费毛片麻豆| 毛片一区二区三区四区| 国产精品亲子伦对白| 麻豆传媒在线播放| 色视频成人在线观看免| 亚洲成人三级| 欧美人与禽zozo性伦| 国产很黄免费观看久久| h短视频大全在线观看| 日韩av综合在线观看| 国产资源在线一区| 中文字幕第12页| 性做久久久久久免费观看| 免费在线看电影| 国产乱真实合集| 日韩一级性生活片| 精品亚洲aⅴ在线观看| 亚洲深夜激情| 久久人妻精品白浆国产| 91精品国产综合久久久久| 久久久久久爱| 日本欧洲一区| 制服诱惑亚洲| 国产精品人妖ts系列视频| 亚洲伦乱视频| 日本少妇一区| 欧美亚洲日本在线观看| 欧美另类xxx| 好吊成人免视频| 国产一区二区三区精品视频| 一本久道久久综合狠狠爱亚洲精品| 最新国产精品亚洲| 四虎5151久久欧美毛片| 黄网站免费在线播放| 国产高清精品在线观看| 北条麻妃69av| 95在线视频| av人人综合网| 777午夜精品电影免费看| 黄色av电影在线观看| 成熟丰满熟妇高潮xxxxx视频| 亚洲免费成人av| 免费永久网站黄欧美| 国产成人精品123区免费视频| 成年人在线播放| 日韩欧美视频一区| 国产自产2019最新不卡| 国产精品成人**免费视频| 在线成人激情| 国产精品一区高清| 成人线上视频| 啊v视频在线| 无码播放一区二区三区| 91国自产精品中文字幕亚洲| 精品动漫一区二区三区| 图片婷婷一区| 亚洲久草在线| 69xxx在线| 韩日精品视频一区| 蜜桃av噜噜一区| 国产精品视频一二| 不卡影院免费观看| 国产一区二区精品在线观看| 九九热播视频在线精品6| 97国产视频| 亚洲午夜精品福利| 成人av免费在线看| 成人羞羞国产免费| 久久亚洲精品小早川怜子| 日本不卡免费一区| 婷婷综合五月| 警花av一区二区三区| 第四色在线一区二区| 清纯唯美激情亚洲| 国产精品xnxxcom| 精品国产乱子伦一区二区| 福利小视频在线| 国产午夜福利在线播放| 欧美午夜性视频| 国产男女免费视频| av电影在线观看一区二区三区| 国产精品免费不| 亚洲精品一二| 成人看片爽爽爽| 黄色在线论坛| 九九热线视频只有这里最精品| yw193.com尤物在线| 黄色在线免费网站| 国产视频一二| 91社区在线观看播放| www555久久| 欧美 亚洲 视频| 国产日产亚洲精品| 麻豆亚洲一区| 日本五码在线| 57pao成人永久免费| 午夜精品影院| 日韩高清在线一区| 亚洲女与黑人做爰| 中文字幕精品在线不卡| 成人精品一区二区三区中文字幕| 粉嫩欧美一区二区三区高清影视| 国产亚洲一级| 欧美成人一品| 亚洲激情网站| 经典一区二区三区| 中文字幕一区二区不卡 | 成人黄色网址在线观看| 国产亚洲一区二区在线观看| 亚洲成a人在线观看| 91国内精品野花午夜精品| 亚洲国产99精品国自产| 中文字幕欧美在线| 国产福利精品在线| 久久精品一区二区三区不卡免费视频 | 青春草在线视频免费观看| 黄色动漫网站入口| 91社区在线高清| 久久精品亚洲成在人线av网址| 老妇喷水一区二区三区| 久久九九99视频| 日韩免费高清视频| 国产成人久久久精品一区| 日本一区二区三区视频在线观看 | 成人全视频免费观看在线看| 免费欧美激情| 99久久免费视频.com| 日韩三级中文字幕| 国产不卡av在线| 搞av.com| 乡村艳史在线观看| 激情成人亚洲| 性欧美疯狂xxxxbbbb| 日韩av免费在线| 青青在线免费观看视频| 在线播放麻豆| 国产一二三区在线| 91午夜精品| 一本色道久久精品| 亚洲国产美女搞黄色| 日本国产高清不卡|