自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何解決Redis緩存雪崩、緩存穿透、緩存并發(fā)等5大難題

存儲 存儲軟件 Redis
Java相關(guān)的面試都會問到緩存的問題:緩存雪崩、緩存穿透、緩存預熱、緩存更新、緩存降級等不常見的問題,但卻是非常重要的問題,今天談談這個話題。

 Java相關(guān)的面試都會問到緩存的問題:緩存雪崩、緩存穿透、緩存預熱、緩存更新、緩存降級等不常見的問題,但卻是非常重要的問題,今天談談這個話題。

基本看完這篇,可以對redis有一個比較全面的初步了解,后續(xù)我再補充redis相關(guān)的實戰(zhàn)篇,總結(jié)為一個redis系列。

01.緩存雪崩

數(shù)據(jù)未加載到緩存中,或者緩存同一時間大面積的失效,從而導致所有請求都去查數(shù)據(jù)庫,導致數(shù)據(jù)庫CPU和內(nèi)存負載過高,甚至宕機。

比如一個雪崩的簡單過程:

1、redis集群大面積故障

2、緩存失效,但依然大量請求訪問緩存服務redis

3、redis大量失效后,大量請求轉(zhuǎn)向到mysql數(shù)據(jù)庫

4、mysql的調(diào)用量暴增,很快就扛不住了,甚至直接宕機

5、由于大量的應用服務依賴mysql和redis的服務,這個時候很快會演變成各服務器集群的雪崩,***網(wǎng)站徹底崩潰。

 

 

02.緩存雪崩解決方案

 

 

1.緩存的高可用性

緩存層設計成高可用,防止緩存大面積故障。即使個別節(jié)點、個別機器、甚至是機房宕掉,依然可以提供服務,例如 Redis Sentinel 和 Redis Cluster 都實現(xiàn)了高可用。

2.緩存降級

可以利用ehcache等本地緩存(暫時使用),但主要還需要對源服務訪問進行限流、資源隔離(熔斷)、降級等。

當訪問量劇增、服務出現(xiàn)問題仍然需要保證服務還是可用的。系統(tǒng)可以根據(jù)一些關(guān)鍵數(shù)據(jù)進行自動降級,也可以配置開關(guān)實現(xiàn)人工降級,這里會涉及到運維的配合。

降級的最終目的是保證核心服務可用,即使是有損的。

比如我的淘寶頁面,由于是非核心頁面,后端服務如果暫時不能提供使用的情況,可以考慮直接使用一個靜態(tài)頁面替換掉,這樣對于用戶也是永遠提供服務的狀態(tài)(再發(fā)報警信息提示急需解決),也不至于出現(xiàn)空白或者異常錯誤的裸奔狀態(tài)。

在進行降級之前要對系統(tǒng)進行梳理,比如:哪些業(yè)務是核心(必須保證),哪些業(yè)務可以容許暫時不提供服務(利用靜態(tài)頁面替換)等,以及配合服務器核心指標,來后設置整體預案,比如:

(1)一般:比如有些服務偶爾因為網(wǎng)絡抖動或者服務正在上線而超時,可以自動降級;

(2)警告:有些服務在一段時間內(nèi)成功率有波動(如在95~100%之間),可以自動降級或人工降級,并發(fā)送告警;

(3)錯誤:比如可用率低于90%,或者數(shù)據(jù)庫連接池被打爆了,或者訪問量突然猛增到系統(tǒng)能承受的***閥值,此時可以根據(jù)情況自動降級或者人工降級;

(4)嚴重錯誤:比如因為特殊原因數(shù)據(jù)錯誤了,此時需要緊急人工降級。

3.Redis備份和快速預熱

1)Redis數(shù)據(jù)備份和恢復

2)快速緩存預熱

3).提前演練

***,建議還是在項目上線前,演練緩存層宕掉后,應用以及后端的負載情況以及可能出現(xiàn)的問題,對高可用提前預演,提前發(fā)現(xiàn)問題。

03.緩存穿透

緩存穿透是指查詢一個一不存在的數(shù)據(jù)。例如:從緩存redis沒有***,需要從mysql數(shù)據(jù)庫查詢,查不到數(shù)據(jù)則不寫入緩存,這將導致這個不存在的數(shù)據(jù)每次請求都要到數(shù)據(jù)庫去查詢,造成緩存穿透。

解決思路:

如果查詢數(shù)據(jù)庫也為空,直接設置一個默認值存放到緩存,這樣第二次到緩沖中獲取就有值了,而不會繼續(xù)訪問數(shù)據(jù)庫。設置一個過期時間或者當有值的時候?qū)⒕彺嬷械闹堤鎿Q掉即可。

可以給key設置一些格式規(guī)則,然后查詢之前先過濾掉不符合規(guī)則的Key。

04.緩存并發(fā)

這里的并發(fā)指的是多個redis的client同時set key引起的并發(fā)問題。其實redis自身就是單線程操作,多個client并發(fā)操作,按照先到先執(zhí)行的原則,先到的先執(zhí)行,其余的阻塞。當然,另外的解決方案是把redis.set操作放在隊列中使其串行化,必須的一個一個執(zhí)行。

05.緩存預熱

緩存預熱就是系統(tǒng)上線后,將相關(guān)的緩存數(shù)據(jù)直接加載到緩存系統(tǒng)。

這樣就可以避免在用戶請求的時候,先查詢數(shù)據(jù)庫,然后再將數(shù)據(jù)緩存的問題,用戶直接查詢事先被預熱的緩存數(shù)據(jù)。

解決思路:

1、直接寫個緩存刷新頁面,上線時手工操作下。

2、數(shù)據(jù)量不大,可以在項目啟動的時候自動進行加載。

目的就是在系統(tǒng)上線前,將數(shù)據(jù)加載到緩存中。

責任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2023-03-10 13:33:00

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

2019-10-12 14:19:05

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

2022-03-08 00:07:51

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

2021-06-05 09:01:01

Redis緩存雪崩緩存穿透

2020-03-16 14:57:24

Redis面試雪崩

2019-11-05 14:24:31

緩存雪崩框架

2023-11-10 14:58:03

2023-04-14 07:34:19

2023-12-06 13:38:00

Redis緩存穿透緩存擊穿

2022-05-27 07:57:20

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

2020-03-05 09:09:18

緩存原因方案

2020-09-14 06:57:30

緩存穿透雪崩

2017-12-27 12:01:39

2020-12-28 12:37:36

緩存擊穿穿透

2024-03-12 10:44:42

2022-08-28 16:31:11

緩存雪崩

2022-11-18 14:34:28

2020-10-13 07:44:40

緩存雪崩 穿透

2021-12-25 22:28:27

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

2024-11-19 12:00:00

緩存擊穿緩存緩存穿透
點贊
收藏

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