欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 詳細分析Redis集群故障

詳細分析Redis集群故障

熱門標簽:玄武湖地圖標注 竹間科技AI電銷機器人 西藏教育智能外呼系統價格 百度商家地圖標注怎么做 最簡單的百度地圖標注 小紅書怎么地圖標注店 地圖標注如何即時生效 地圖標注費用 太原營銷外呼系統

故障表象:

業務層面顯示提示查詢redis失敗

集群組成:

3主3從,每個節點的數據有8GB

機器分布:

在同一個機架中,

xx.x.xxx.199
xx.x.xxx.200
xx.x.xxx.201

redis-server進程狀態:

通過命令ps -eo pid,lstart | grep $pid,

發現進程已經持續運行了3個月

發生故障前集群的節點狀態:

xx.x.xxx.200:8371(bedab2c537fe94f8c0363ac4ae97d56832316e65) master
xx.x.xxx.199:8373(792020fe66c00ae56e27cd7a048ba6bb2b67adb6) slave
xx.x.xxx.201:8375(5ab4f85306da6d633e4834b4d3327f45af02171b) master
xx.x.xxx.201:8372(826607654f5ec81c3756a4a21f357e644efe605a) slave
xx.x.xxx.199:8370(462cadcb41e635d460425430d318f2fe464665c5) master
xx.x.xxx.200:8374(1238085b578390f3c8efa30824fd9a4baba10ddf) slave

---------------------------------下面是日志分析--------------------------------------

步1:
主節點8371失去和從節點8373的連接:
46590:M 09 Sep 18:57:51.379 # Connection with slave xx.x.xxx.199:8373 lost.

步2:
主節點8370/8375判定8371失聯:
42645:M 09 Sep 18:57:50.117 * Marking node bedab2c537fe94f8c0363ac4ae97d56832316e65 as failing (quorum reached).

步3:
從節點8372/8373/8374收到主節點8375說8371失聯:
46986:S 09 Sep 18:57:50.120 * FAIL message received from 5ab4f85306da6d633e4834b4d3327f45af02171b about bedab2c537fe94f8c0363ac4ae97d56832316e65

步4:
主節點8370/8375授權8373升級為主節點轉移:
42645:M 09 Sep 18:57:51.055 # Failover auth granted to 792020fe66c00ae56e27cd7a048ba6bb2b67adb6 for epoch 16

步5:
原主節點8371修改自己的配置,成為8373的從節點:
46590:M 09 Sep 18:57:51.488 # Configuration change detected. Reconfiguring myself as a replica of 792020fe66c00ae56e27cd7a048ba6bb2b67adb6

步6:
主節點8370/8375/8373明確8371失敗狀態:
42645:M 09 Sep 18:57:51.522 * Clear FAIL state for node bedab2c537fe94f8c0363ac4ae97d56832316e65: master without slots is reachable again.

步7:
新從節點8371開始從新主節點8373,第一次全量同步數據:
8373日志::
4255:M 09 Sep 18:57:51.906 * Full resync requested by slave xx.x.xxx.200:8371
4255:M 09 Sep 18:57:51.906 * Starting BGSAVE for SYNC with target: disk
4255:M 09 Sep 18:57:51.941 * Background saving started by pid 5230
8371日志::
46590:S 09 Sep 18:57:51.948 * Full resync from master: d7751c4ebf1e63d3baebea1ed409e0e7243a4423:440721826993

步8:
主節點8370/8375判定8373(新主)失聯:
42645:M 09 Sep 18:58:00.320 * Marking node 792020fe66c00ae56e27cd7a048ba6bb2b67adb6 as failing (quorum reached).

步9:
主節點8370/8375判定8373(新主)恢復:
60295:M 09 Sep 18:58:18.181 * Clear FAIL state for node 792020fe66c00ae56e27cd7a048ba6bb2b67adb6: is reachable again and nobody is serving its slots after some time.

步10:
主節點8373完成全量同步所需要的BGSAVE操作:
5230:C 09 Sep 18:59:01.474 * DB saved on disk
5230:C 09 Sep 18:59:01.491 * RDB: 7112 MB of memory used by copy-on-write
4255:M 09 Sep 18:59:01.877 * Background saving terminated with success

步11:
從節點8371開始從主節點8373接收到數據:
46590:S 09 Sep 18:59:02.263 * MASTER -> SLAVE sync: receiving 2657606930 bytes from master

步12:
主節點8373發現從節點8371對output buffer作了限制:
4255:M 09 Sep 19:00:19.014 # Client id=14259015 addr=xx.x.xxx.200:21772 fd=844 name= age=148 idle=148 flags=S db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=16349 oll=4103 omem=95944066 events=rw cmd=psync scheduled to be closed ASAP for overcoming of output buffer limits.
4255:M 09 Sep 19:00:19.015 # Connection with slave xx.x.xxx.200:8371 lost.

步13:
從節點8371從主節點8373同步數據失敗,連接斷了,第一次全量同步失敗:
46590:S 09 Sep 19:00:19.018 # I/O error trying to sync with MASTER: connection lost
46590:S 09 Sep 19:00:20.102 * Connecting to MASTER xx.x.xxx.199:8373
46590:S 09 Sep 19:00:20.102 * MASTER -> SLAVE sync started

步14:
從節點8371重新開始同步,連接失敗,主節點8373的連接數滿了:
46590:S 09 Sep 19:00:21.103 * Connecting to MASTER xx.x.xxx.199:8373
46590:S 09 Sep 19:00:21.103 * MASTER -> SLAVE sync started
46590:S 09 Sep 19:00:21.104 * Non blocking connect for SYNC fired the event.
46590:S 09 Sep 19:00:21.104 # Error reply to PING from master: '-ERR max number of clients reached'

步15:
從節點8371重新連上主節點8373,第二次開始全量同步:
8371日志:
46590:S 09 Sep 19:00:49.175 * Connecting to MASTER xx.x.xxx.199:8373
46590:S 09 Sep 19:00:49.175 * MASTER -> SLAVE sync started
46590:S 09 Sep 19:00:49.175 * Non blocking connect for SYNC fired the event.
46590:S 09 Sep 19:00:49.176 * Master replied to PING, replication can continue...
46590:S 09 Sep 19:00:49.179 * Partial resynchronization not possible (no cached master)
46590:S 09 Sep 19:00:49.501 * Full resync from master: d7751c4ebf1e63d3baebea1ed409e0e7243a4423:440780763454
8373日志:
4255:M 09 Sep 19:00:49.176 * Slave xx.x.xxx.200:8371 asks for synchronization
4255:M 09 Sep 19:00:49.176 * Full resync requested by slave xx.x.xxx.200:8371
4255:M 09 Sep 19:00:49.176 * Starting BGSAVE for SYNC with target: disk
4255:M 09 Sep 19:00:49.498 * Background saving started by pid 18413
18413:C 09 Sep 19:01:52.466 * DB saved on disk
18413:C 09 Sep 19:01:52.620 * RDB: 2124 MB of memory used by copy-on-write
4255:M 09 Sep 19:01:53.186 * Background saving terminated with success

步16:
從節點8371同步數據成功,開始加載經內存:
46590:S 09 Sep 19:01:53.190 * MASTER -> SLAVE sync: receiving 2637183250 bytes from master
46590:S 09 Sep 19:04:51.485 * MASTER -> SLAVE sync: Flushing old data
46590:S 09 Sep 19:05:58.695 * MASTER -> SLAVE sync: Loading DB in memory

步17:
集群恢復正常:
42645:M 09 Sep 19:05:58.786 * Clear FAIL state for node bedab2c537fe94f8c0363ac4ae97d56832316e65: slave is reachable again.

步18:
從節點8371同步數據成功,耗時7分鐘:
46590:S 09 Sep 19:08:19.303 * MASTER -> SLAVE sync: Finished with success

8371失聯原因分析:

由于幾臺機器在同一個機架,不太可能發生網絡中斷的情況,于是通過SLOWLOG GET命令查看了慢查詢日志,發現有一個KEYS命令被執行了,耗時8.3秒,再查看集群節點超時設置,發現是5s(cluster-node-timeout 5000)

出現節點失聯的原因:

客戶端執行了耗時1條8.3s的命令,

2016/9/9 18:57:43 開始執行KEYS命令
2016/9/9 18:57:50 8371被判斷失聯(redis日志)
2016/9/9 18:57:51 執行完KEYS命令

總結來說,有以下幾個問題:

1.由于cluster-node-timeout設置比較短,慢查詢KEYS導致了集群判斷節點8371失聯

2.由于8371失聯,導致8373升級為主,開始主從同步

3.由于配置client-output-buffer-limit的限制,導致第一次全量同步失敗了

4.又由于PHP客戶端的連接池有問題,瘋狂連接服務器,產生了類似SYN攻擊的效果

5.第一次全量同步失敗后,從節點重連主節點花了30秒(超過了最大連接數1w)

關于client-output-buffer-limit參數:

# The syntax of every client-output-buffer-limit directive is the following: 
# 
# client-output-buffer-limit class> hard limit> soft limit> soft seconds> 
# 
# A client is immediately disconnected once the hard limit is reached, or if 
# the soft limit is reached and remains reached for the specified number of 
# seconds (continuously). 
# So for instance if the hard limit is 32 megabytes and the soft limit is 
# 16 megabytes / 10 seconds, the client will get disconnected immediately 
# if the size of the output buffers reach 32 megabytes, but will also get 
# disconnected if the client reaches 16 megabytes and continuously overcomes 
# the limit for 10 seconds. 
# 
# By default normal clients are not limited because they don't receive data 
# without asking (in a push way), but just after a request, so only 
# asynchronous clients may create a scenario where data is requested faster 
# than it can read. 
# 
# Instead there is a default limit for pubsub and slave clients, since 
# subscribers and slaves receive data in a push fashion. 
# 
# Both the hard or the soft limit can be disabled by setting them to zero. 
client-output-buffer-limit normal 0 0 0 
client-output-buffer-limit slave 256mb 64mb 60 
client-output-buffer-limit pubsub 32mb 8mb 60 

采取措施:

1.單實例的切割到4G以下,否則發生主從切換會耗時很長

2.調整client-output-buffer-limit參數,防止同步進行到一半失敗

3.調整cluster-node-timeout,不能少于15s

4.禁止任何耗時超過cluster-node-timeout的慢查詢,因為會導致主從切換

5.修復客戶端類似SYN攻擊的瘋狂連接方式

總結

以上就是本文關于詳細分析Redis集群故障的全部內容,希望對大家有所幫助。感興趣的朋友可以參閱:Spring AOP實現Redis緩存數據庫查詢源碼、簡述Redis和MySQL的區別、oracle 數據庫啟動階段分析等,如有不足之處,請留言之處。小編會及時更正。感謝朋友們對腳本之家網站的支持!

您可能感興趣的文章:
  • 基于docker搭建redis集群的方法
  • Docker 部署單機版 Pulsar 和集群架構 Redis(開發神器)的方法
  • Redis Cluster集群數據分片機制原理
  • springcloud微服務基于redis集群的單點登錄實現解析
  • springboot整合redis集群過程解析
  • Redis集群下過期key監聽的實現代碼
  • Java調用Redis集群代碼及問題解決
  • Linux(Centos7)下redis5集群搭建和使用說明詳解
  • 基于docker搭建redis-sentinel集群的方法示例
  • 比較幾種Redis集群方案

標簽:唐山 揚州 贛州 香港 澳門 景德鎮 林芝 廣東

巨人網絡通訊聲明:本文標題《詳細分析Redis集群故障》,本文關鍵詞  詳細,分析,Redis,集群,故障,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳細分析Redis集群故障》相關的同類信息!
  • 本頁收集關于詳細分析Redis集群故障的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲欧美日韩在线不卡| 久久99精品久久久久| 成人三级在线视频| 呻吟揉丰满对白91乃国产区| 欧美成人精品福利| 日韩精品一卡二卡三卡四卡无卡| 日韩精品xxx| 在线观看网站黄不卡| 自拍av一区二区三区| 成人免费看视频| 日本午夜在线观看| 国产精品久久久久久久久晋中| 国产一区二区在线免费观看| 国产又黄又粗的视频| 久久久久久亚洲综合影院红桃| 久久激情五月激情| 国产又黄又粗视频| 国产午夜精品一区二区三区视频| 黑人巨大精品欧美黑白配亚洲| 妺妺窝人体色WWW精品| 2021中文字幕一区亚洲| 国产一区在线看| 性色国产成人久久久精品| 国产精品三级视频| av不卡免费电影| 欧美亚洲尤物久久| 亚洲1区2区3区视频| 极品人妻一区二区三区| 欧美精品一区二区高清在线观看| 国内精品第一页| 国产精品成人69xxx免费视频| 一区精品在线播放| 国产裸体视频网站| 日韩限制级电影在线观看| 久久精品国产999大香线蕉| 懂色av粉嫩av浪潮av| 中文字幕一区二区三区在线不卡 | 亚洲综合色在线| 美女黄色一级视频| 精品国产一区二区三区四区四| 国产一区二区三区久久久| 国产女人18水真多毛片18精品| 亚洲人成网站色在线观看| www.啪啪.com| 久久综合久久综合久久| 丁香啪啪综合成人亚洲小说| 欧美色电影在线| 五月婷婷一区二区| 一区二区三区国产精品| 真人bbbbbbbbb毛片| 久久久精品2019中文字幕之3| 国产精品一区二区久久不卡 | 波多野吉衣在线视频| 欧美一级欧美三级| 国产电影精品久久禁18| 欧美日韩中文字幕一区| 精品一二三四区| 91久久精品午夜一区二区| 日韩精品一卡二卡三卡四卡无卡| 国产黄色录像视频| 一区二区三区四区国产精品| 久久精品国产亚洲av久| 国产精品麻豆99久久久久久| 污污免费在线观看| 中文字幕国产一区二区| 久久精品无码专区| 国产欧美日韩卡一| 天堂www中文在线资源| 亚洲国产精品成人综合| 亚洲啪av永久无码精品放毛片 | 亚洲在线视频网站| 性猛交娇小69hd| 一区二区三区四区五区视频在线观看| 午夜一区二区三区免费| 中文字幕在线视频一区| 亚洲午夜福利在线观看| 亚洲美女区一区| 亚欧精品视频一区二区三区| 亚洲成人综合网站| 免费成年人视频在线观看| 琪琪久久久久日韩精品| 91高清在线观看| 韩国精品久久久| 制服视频三区第一页精品| 成人午夜在线视频| 2023国产精品| 中出视频在线观看| 一区二区三区**美女毛片| 国产日韩精品中文字无码| 首页综合国产亚洲丝袜| 日本精品一级二级| 国产成人自拍在线| 精品福利一二区| 国产精品成人99一区无码| 亚洲人成网站色在线观看| 亚洲欧美卡通动漫| 美女高潮久久久| 欧美人成免费网站| www.成人网.com| 欧美激情综合五月色丁香小说| 一女三黑人理论片在线| 亚洲一区在线观看视频| 国产探花在线播放| 国产电影一区二区三区| 337p粉嫩大胆色噜噜噜噜亚洲| 国产一卡二卡三卡四卡| 一区二区三区中文字幕电影| 国产精品 欧美激情| 国产一区中文字幕| 成人欧美精品一区二区| 亚洲理论在线观看| 欧美亚洲日本在线| 国产91在线|亚洲| 国产日韩影视精品| 免费成人深夜天涯网站| 免费精品视频在线| 日韩一级精品视频在线观看| 国产精品日日摸夜夜爽| 一区二区激情小说| 91精品福利视频| 99精品国产一区二区三区不卡| 国产网红主播福利一区二区| 卡一卡二卡三在线观看| 另类人妖一区二区av| 日韩精品一区二区三区蜜臀 | 91麻豆精品国产综合久久久久久| 日韩精品xxx| 亚洲成人动漫在线免费观看| 欧美日韩国产成人在线91| 男人添女人荫蒂国产| 亚洲综合图片区| 欧美日本不卡视频| 中文字幕一区三区久久女搜查官| 亚洲成a人在线观看| 欧美精品日韩一区| 在线视频 日韩| 青青草国产精品亚洲专区无| 欧美一级久久久| 精品久久久久久中文字幕人妻最新| 日韩va欧美va亚洲va久久| 日韩视频国产视频| 中文字幕免费视频| 国产一区二区三区高清播放| 日本一二三四高清不卡| 精品国产欧美日韩不卡在线观看| jlzzjlzz亚洲日本少妇| 亚洲综合久久av| 91精品国产91久久久久久一区二区 | 午夜精品影院在线观看| 91精品国产91热久久久做人人| 黑人巨大精品欧美| 国产精品一二三| 亚洲日本在线天堂| 欧美日本一区二区在线观看| 制服丝袜第二页| 国产一区二区三区四区在线观看| 欧美国产欧美亚州国产日韩mv天天看完整 | 久久久久国产精品厨房| 永久av免费网站| 91亚洲国产成人精品一区二三| 亚洲一区av在线| 欧美变态tickling挠脚心| 长河落日免费高清观看| 97精品超碰一区二区三区| 午夜视频一区在线观看| 亚洲精品在线一区二区| 欧美风情第一页| 国产精品一区二区在线免费观看| 免费在线观看成人| 国产精品午夜免费| 欧美日韩国产综合草草| 欧美 日韩 国产 成人 在线观看 | 国产一区二区三区综合| 亚洲日本在线看| 日韩欧美在线123| 久久噜噜色综合一区二区| 亚洲v在线观看| 国产综合久久久久影院| 亚洲精品视频在线| 欧美成人一区二区三区片免费 | 日韩精品福利网| 国产片一区二区三区| 欧美在线一二三四区| 四虎影成人精品a片| 成人午夜精品一区二区三区| 性做久久久久久免费观看| 国产日韩欧美精品综合| 欧美少妇一区二区| 精品手机在线视频| 日本中文字幕有码| 国产一区二区三区久久悠悠色av| 亚洲精品午夜久久久| 2017欧美狠狠色| 欧美视频一二三区| 欧美乱大交做爰xxxⅹ小说| 无码人妻一区二区三区一| 国产美女精品在线| 午夜精品福利一区二区三区av| 中文字幕精品一区二区精品绿巨人| 在线播放视频一区|