redis集群宕機

来源:https://www.cnblogs.com/Snail-1174158844/archive/2018/08/26/9538155.html
-Advertisement-
Play Games

redis集群是有很多個redis一起工作,那麼就需要這個集群不是那麼容易掛掉,所以呢,理論上就應該給集群中的每個節點至少一個備用的redis服務。這個備用的redis稱為從節點(slave)。 1、集群是如何判斷是否有某個節點掛掉 首先要說的是,每一個節點都存有這個集群所有主節點以及從節點的信息。 ...


redis集群是有很多個redis一起工作,那麼就需要這個集群不是那麼容易掛掉,所以呢,理論上就應該給集群中的每個節點至少一個備用的redis服務。這個備用的redis稱為從節點(slave)。

1、集群是如何判斷是否有某個節點掛掉

  首先要說的是,每一個節點都存有這個集群所有主節點以及從節點的信息。它們之間通過互相的ping-pong判斷是否節點可以連接上。如果有一半以上的節點去ping一個節點的時候沒有回應,集群就認為這個節點宕機了,然後去連接它的備用節點。

 

2、集群進入fail狀態的必要條件

A、某個主節點和所有從節點全部掛掉,我們集群就進入faill狀態。

B、如果集群超過半數以上master掛掉,無論是否有slave,集群進入fail狀態.

 C、如果集群任意master掛掉,且當前master沒有slave.集群進入fail狀態

 

3、redis的投票機制

具體原理如下圖所示:

    

投票過程是集群中所有master參與,如果半數以上master節點與master節點通信超時(cluster-node-timeout),認為當前master節點掛掉。

    選舉的依據依次是:網路連接正常->5秒內回覆過INFO命令->10*down-after-milliseconds內與主連接過的->從伺服器優先順序->複製偏移量->運行id較小的。選出之後通過slaveif no ont將該從伺服器升為新主伺服器。

    通過slaveof ip port命令讓其他從伺服器複製該信主伺服器。

    最後當舊主重新連接後將其變為新主的從伺服器。註意如果客戶端與舊主伺服器分隔在一起,寫入的數據在恢復後由於舊主會複製新主的數據會造成數據丟失。

4、集群中的主從複製
      集群中的每個節點都有1個至N個複製品,其中一個為主節點,其餘的為從節點,如果主節點下線了,集群就會把這個主節點的一個從節點設置為新的主節點繼續工作,這樣集群就不會因為一個主節點的下線而無法正常工作。
註意:
1、如果某一個主節點和他所有的從節點都下線的話,redis集群就會停止工作了。redis集群不保證數據的強一致性,在特定的情況下,redis集群會丟失已經被執行過的寫命令。
2、使用非同步複製(asynchronous replication)是redis 集群可能會丟失寫命令的其中一個原因,有時候由於網路原因,如果網路斷開時間太長,redis集群就會啟用新的主節點,之前發給主節點的數據就會丟失。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 整體環境配置 整體環境的配置,如果一個一個 Dockerfile 去寫,那麼是相當麻煩的,好在 Docker 有一個名為 Docker-Compose 的工具提供,我們可以使用它一次性完成整體環境的配置: 首先我們看看 docker-compose.yml 配置文件的內容:version: "3"s ...
  • if else判斷語句 if語句 語法格式1: 語法格式2: 常用於終端命令提示符中 if else語句 語法格式: if else-if else語句 語法格式: for迴圈語句 語法格式1: 語法格式2: 常用於終端命令提示符中 for死迴圈 語法格式: while迴圈語句 用於不斷執行一系列命 ...
  • 第1章 sed基礎 1.1 sed的選項 stream editor 流編輯器 -r 支持擴展正則 -n 取消預設輸出 -i 直接修改不輸出到桌面 -i.bak 備份 1.2 sed的書寫格式 sed '條件命令' sed 'pattern命令' sed '模式命令' 1.3 sed命令執行過程 1 ...
  • 前幾篇介紹了基礎,這篇將具體實現幾個案例 實現基於文件驗證的vsftpd虛擬用戶,每個用戶獨立一個文件夾 1、創建用戶資料庫文件 備註:文件內容格式為奇數行為用戶名,偶數行為密碼 2、設置許可權與編譯此文件 備註:修改許可權是為了安全 3、創建linux用戶和ftp目錄(這個賬號將來虛擬賬號映射成它) ...
  • 介紹:文件傳輸協議FTP 兩種模式:伺服器角度 主動(PORT style):伺服器主動連接 命令(控制):客戶端:隨機port  伺服器:tcp21 數據:客戶端:隨機port  伺服器:tcp20 被動(PASV style):客戶端主動連接 命令(控制):客戶端:隨機port  伺服器: ...
  • 集群,為解決某個特定問題將多台電腦組合起來形成的單個系統lvs-nat:本質是多目標IP的DNAT,通過將請求報文中的目標地址和目標埠修改為某挑出的RS的RIP和PORT實現轉發lvs集群類型中的術語:VS:Virtual Server,Director Server(DS)Dispatcher... ...
  • 將mssql資料庫高版本遷移到低版本 ...
  • 作者:灬花兒灬 出處:http://www.cnblogs.com/flower1990/ 本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。 本文在排版和內容上做了點小修改。 一、安裝JAVA JDK 1、下載安裝包 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...