Java面試八股之Redis哨兵機制

  1. Redis哨兵機制

Redis Sentinel(哨兵)模式是一種高可用解決方案,用于監控和自動故障轉移Redis主從集群。以下是對哨兵模式詳細過程的描述:

1. 初始化與配置

部署哨兵節點:在不同的服務器上部署一個或多個Redis Sentinel節點,它們作為獨立進程運行,負責監控Redis主從集群的狀態。

配置監控:為每個哨兵節點配置要監控的主節點(以及其從節點),包括主節點的IP地址、端口、密碼(如有)以及監控間隔等參數。

配置哨兵間通信:哨兵節點之間需要通過發布與訂閱機制相互通信,以便共享狀態信息、進行協商和達成共識。配置哨兵間的心跳檢測間隔、通信頻道等參數。

配置故障轉移參數:設定故障轉移所需的條件,如主觀下線(SDOWN)和客觀下線(ODOWN)的判定條件(如連續多少次心跳檢測失敗)、故障轉移的最小投票數(quorum)、故障轉移超時時間、從節點選擇策略等。

2. 哨兵監控與心跳檢測

周期性監控:每個哨兵節點定期向主節點和從節點發送INFO和PING命令,獲取它們的狀態信息(如角色、連接數、復制進度等)和確認節點存活。

主觀下線(SDOWN):當哨兵節點連續多次無法與某個節點(通常是主節點)建立連接或收到響應時,它會將該節點標記為“主觀下線”。此時,該哨兵認為主節點有問題,但尚未與其他哨兵達成一致意見。

3. 故障通知與協商

發送哨兵間消息:標記為主觀下線的哨兵節點會向其他哨兵節點發送消息,告知其對主節點的判斷。其他哨兵接收到消息后,也會獨立地對主節點進行檢測。

客觀下線(ODOWN):當足夠數量(超過配置的quorum)的哨兵都將主節點標記為SDOWN時,主節點被認定為“客觀下線”。這意味著大部分哨兵都觀察到了主節點的問題,形成了共識。

4. 主節點故障轉移

選舉領導者(Leader Sentinel):在確認主節點ODOWN后,哨兵節點間啟動選舉流程,通過Raft或其他類似共識算法選出一個領導者哨兵負責執行故障轉移操作。領導者哨兵可能是最先標記主節點ODOWN的哨兵,也可能是在選舉過程中獲得多數投票的哨兵。

選擇新主節點:領導者哨兵根據配置的從節點選擇策略(如優先選擇復制偏移量最大的從節點,表示數據最完整)從健康的從節點中選擇一個作為新的主節點。

執行故障轉移:領導者哨兵向選定的從節點發送SLAVEOF NO ONE命令,使其晉升為主節點。同時,通知其他從節點重新配置復制關系,開始從新主節點復制數據。

更新客戶端配置:領導者哨兵更新配置,將原主節點的客戶端重定向到新主節點,并通過發布哨兵配置變更消息,讓其他哨兵和客戶端知曉新的主從關系。

原主節點恢復(可選):當原主節點恢復在線時,哨兵會將其自動配置為新主節點的從節點,等待后續可能的手動或自動故障恢復。

5. 健康監測與自動修復

持續監控:哨兵節點持續監控整個Redis集群的狀態,包括新主節點和從節點的健康狀況。

故障自動修復:如果新的主從關系出現問題(如新主節點故障),哨兵會再次觸發故障轉移流程,選舉新的主節點,確保集群的高可用性。

6. 客戶端接入與通知

客戶端連接:客戶端(應用程序)可以通過哨兵提供的服務發現接口(如SENTINEL get-master-addr-by-name <master-name>)動態獲取當前主節點的地址,實現自動連接到正確的主節點。

事件通知:哨兵支持向客戶端發送故障轉移等重要事件的通知,客戶端可以根據這些通知進行相應的處理,如更新本地緩存、重連等。

綜上所述,Redis Sentinel模式通過哨兵節點的監控、協商、故障轉移等過程,實現了對Redis主從集群的自動化管理和高可用保障。當主節點出現故障時,哨兵能自動識別并觸發故障轉移,確保數據服務的連續性,同時降低了運維復雜性和人工干預成本。

?如果大家需要視頻版本的講解,歡迎關注我的B站:

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/45734.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/45734.shtml
英文地址,請注明出處:http://en.pswp.cn/web/45734.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《算法筆記》總結No.7——二分(多例題詳解版)

一.二分查找 目前有一個有序數列&#xff0c;舉個例子&#xff0c;假設是1~1000&#xff0c;讓我們去查找931這個數字&#xff0c;淺顯且暴力的做法就是直接從頭到尾遍歷一遍&#xff0c;直到找到931為止。當n非常大&#xff0c;比如達到100w時&#xff0c;這是一個非常大的量級…

Linux 線程初步解析

1.線程概念 在一個程序里的一個執行路線就叫做線程&#xff08;thread&#xff09;。更準確的定義是&#xff1a;線程是“一個進程內部的控制序列。在linux中&#xff0c;由于線程和進程都具有id,都需要調度等等相似性&#xff0c;因此都可以用PCB來描述和控制,線程含有PCB&am…

美聯儲降息應該更早?高盛:有充分理由7月降息,而非9月

KlipC報道&#xff1a;高盛首席經濟學家哈祖斯Jan Hatzius表示&#xff0c;美聯儲“有充分理由”在7月會議上降息&#xff0c;而非等到9月。 在最新發布的報告中&#xff0c;他表明通脹已經取得了足夠的進展&#xff0c;回到了美聯儲2%的長期目標附近&#xff0c;這將使美聯儲…

[C++ 入門基礎 - 命名空間]

在C中&#xff0c;命名空間&#xff08;Namespace&#xff09;是一種用來組織代碼并避免命名沖突的機制。命名空間可以包含變量、函數、類等C中的所有實體&#xff0c;使得這些實體的名稱在命名空間內部有效&#xff0c;避免了與其他命名空間或全局作用域中相同名稱的沖突。 文…

實現將Nginx的每個網站配置單獨的訪問日志

一、問題描述 Nginx默認的訪問日志是不會區分哪個網站有哪些日志的,全部糅雜在一起;如果需要哪個網站有哪些訪問日志記錄,還需要將訪問日志下載下來后篩選,比較麻煩;希望將每個網站對應的日志能夠單獨記錄到對應的日志文件里面,方便排查和管理。 # 進入Nginx默認的日志文…

為什么Vim是程序員最喜歡的編輯器之一

簡介 Vim&#xff0c;全稱Vi IMproved&#xff0c;是一種高度可定制、功能強大的文本編輯器。自其誕生以來&#xff0c;它以高效、快速和靈活的特點深受程序員喜愛。無論是處理簡單的文本文件還是復雜的代碼項目&#xff0c;Vim都能提供卓越的編輯體驗。許多資深程序員甚至稱其…

c++ primer plus 第16章string 類和標準模板庫,6.1.5字符串種類

c primer plus 第16章string 類和標準模板庫,6.1.5字符串種類 c primer plus 第16章string 類和標準模板庫,6.1.5字符串種類 文章目錄 c primer plus 第16章string 類和標準模板庫,6.1.5字符串種類6.1.5字符串種類 6.1.5字符串種類 本節將 string 類看作是基于 char 類型的。…

web服務器經過代理后的絕對路徑問題,以及 dirname(__FILE__)和__DIR__

web服務器經過代理后的絕對路徑問題&#xff0c;以及 dirname&#xff08;__FILE__&#xff09;和__DIR__ 問題描述情況解析資源路徑分析訪問過程分析 dirname(\_\_FILE\_\_) 與 \_\_DIR\_\_ 同步發布在個人筆記web服務器經過代理后的絕對路徑問題&#xff0c;以及 dirname(__F…

Nest.js 實戰 (一):使用過濾器優雅地統一處理響應體

前言 在我們實際的業務開發中&#xff0c;我們可以看到后端接口返回格式都有一定的要求&#xff0c;假如我們統一規定接口的統一返回格式為&#xff1a; {data: any; // 業務數據code: number; // 狀態碼msg: string; // 響應信息timestamp: number; // 時間戳 }那么在 Nest.…

【智能算法改進】改進的麻雀搜索算法及其求解旅行商問題

目錄 1.算法原理2.改進點3.結果展示4.參考文獻5.代碼獲取 1.算法原理 【智能算法】麻雀搜索算法&#xff08;SSA&#xff09;原理及實現 2.改進點 改進發現者更新位置 為了使 SSA 算法能夠避開向原點收斂的弊端, 將算法向最優位置跳躍的操作轉換為向最優位置的移動: X i ,…

自己動手寫一個滑動驗證碼組件(后端為Spring Boot項目)

近期參加的項目&#xff0c;主管丟給我一個任務&#xff0c;說要支持滑動驗證碼。我身為50歲的軟件攻城師&#xff0c;當時正背著雙手&#xff0c;好像一個受訓的保安似的&#xff0c;中規中矩地參加每日站會&#xff0c;心想滑動驗證碼在今時今日已經是標配了&#xff0c;司空…

一個篇文章告訴你一個APP前端搭建有多簡單

用uni-app 1.新建uni-app項目 點擊項目 2.創建 最后點擊右下方創建 3.添加tarbar 首先你要創建幾個頁面這里比如說我有兩個頁面的tarbar首頁(home)和我的(userIndex) 在pages目錄下右鍵新建頁面即可

從庫存超賣問題分析鎖和分布式鎖的應用(二)

本文從一個經典的庫存超賣問題分析說明常見鎖的應用&#xff0c;假設庫存資源存儲在Redis里面。 假設我們的減庫存代碼如下&#xff1a; Autowired StringRedisTemplate redisTemplate;public void deduct(){String stock redisTemplate.opsForValue().get("stock"…

JavaSE從零開始到精通

1.前置知識 JVM&#xff1a;java virtrual machine, java虛擬機, 專門用于執行java代碼的一款軟件。JRE&#xff1a;java runtime enviroment, java運行時環境, java官方提供的核心類庫. jre中包含了核心類庫和jvm。JDK: java development kit, java開發工具包, javac.exe, ja…

LVS+Keepalive高可用

1、keepalive 調度器的高可用 vip地址主備之間的切換&#xff0c;主在工作時&#xff0c;vip地址只在主上&#xff0c;vip漂移到備服務器。 在主備的優先級不變的情況下&#xff0c;主恢復工作&#xff0c;vip會飄回到住服務器 1、配優先級 2、配置vip和真實服務器 3、主…

我想做信號通路分析,但我就是不想學編程

“我想做信號通路分析&#xff0c;但我就是不想學編程。” “我又不是生信狗&#xff0c;學代碼會死。” “你們這些做生信的&#xff0c;整天把數據分析搞得神神秘秘&#xff0c;不就是怕被人搶飯碗而已嘛。” “這都沒分析出我想要的結果&#xff0c;不靠譜。” “你們做…

【自學安全防御】二、防火墻NAT智能選路綜合實驗

任務要求&#xff1a; &#xff08;銜接上一個實驗所以從第七點開始&#xff0c;但與上一個實驗關系不大&#xff09; 7&#xff0c;辦公區設備可以通過電信鏈路和移動鏈路上網(多對多的NAT&#xff0c;并且需要保留一個公網IP不能用來轉換) 8&#xff0c;分公司設備可以通過總…

使用Docker創建并運行一個create-react-app應用(超簡單)

創建并運行一個使用 Create React App (CRA) 創建的應用程序的 Docker 容器涉及幾個步驟。以下是一個詳細的過程&#xff0c;包括創建一個簡單的 React 應用、編寫 Dockerfile、構建鏡像以及運行容器。 步驟 1: 創建一個新的 React 應用 如果你還沒有一個 React 應用&#xf…

Java爬蟲安全策略:防止TikTok音頻抓取過程中的請求被攔截

摘要 在當今互聯網時代&#xff0c;數據采集已成為獲取信息的重要手段。然而&#xff0c;隨著反爬蟲技術的不斷進步&#xff0c;爬蟲開發者面臨著越來越多的挑戰。本文將探討Java爬蟲在抓取TikTok音頻時的安全策略&#xff0c;包括如何防止請求被攔截&#xff0c;以及如何提高…

RK3568 安卓12 EC20模塊NOCONN沒有ip的問題(已解決)

從網上東拼西湊找了不少教程&#xff0c;但是里面沒有提到rillib.so需要替換&#xff0c;替換掉就可以上網了&#xff0c;系統也有4G圖標了。 注意&#xff0c;這個rillib.so是移遠提供的。把他們提供的文件放到rk3568_android_sdk/vendor/rockchip/common/phone/lib下&#x…