Redis高可用架構演進面試筆記

1. 主從復制架構

核心概念

核心概念

Redis單節點并發能力有限,通過主從集群實現讀寫分離提升性能:

  • Master節點:負責寫操作
  • Slave節點:負責讀操作,從主節點同步數據

主從同步流程

全量同步(首次同步)

全量同步

  1. 建立連接:從節點向主節點發送同步請求(攜帶replicationid、offset)
  2. 版本校驗:主節點判斷是首次請求,與從節點同步版本信息
  3. 生成快照:主節點執行bgsave生成RDB文件
  4. 數據傳輸:將RDB文件發送給從節點加載
  5. 增量補償:同步期間新寫入的命令記錄到緩沖區(replication buffer),隨后發送給從節點
增量同步(后續同步)

增量同步

  1. 斷線重連:從節點重啟或網絡恢復后請求同步
  2. 偏移量對比:主節點獲取從節點的offset值
  3. 差異同步:從命令日志(replication backlog)中獲取offset之后的數據發送給從節點

關鍵參數

  • replicationid:標識數據集版本
  • offset:復制偏移量,標識同步進度

2. 哨兵機制(Sentinel)

哨兵集群

解決問題

主從架構無法自動故障轉移,引入哨兵實現高可用。

工作原理

健康監測

檢測

  • 心跳檢測:每隔1秒向集群實例發送PING命令
  • 主觀下線:單個哨兵認為實例無響應
  • 客觀下線:超過quorum數量的哨兵都認為實例下線(quorum > 哨兵數/2)
故障轉移

自動選舉新的主節點,選主規則按優先級:

  1. 網絡連接:排除與主節點斷開時間過長的從節點
  2. slave-priority:優先級配置,數值越小優先級越高
  3. 復制偏移量:offset越大(數據越新)優先級越高
  4. 運行ID:ID越小優先級越高

3. 腦裂問題

問題描述

腦分裂

網絡分區導致集群出現兩個Master節點,類似"大腦分裂"。

產生原因

主節點與哨兵、從節點網絡隔離,哨兵誤判主節點下線并選舉新主節點。

危害

  • 客戶端向舊主節點寫入數據
  • 新主節點無法同步這些數據
  • 網絡恢復后數據丟失

解決方案

配置參數限制寫入條件:

min-replicas-to-write 1        # 至少1個從節點在線
min-replicas-max-lag 5         # 主從同步延遲不超過5秒

4. 分片集群(Cluster)

分片集群

解決問題

主從+哨兵仍存在兩個核心問題:

  • 海量數據存儲:單主節點內存限制
  • 高并發寫入:單主節點寫入瓶頸

集群特征

  • 多個Master節點,每個存儲不同數據
  • 每個Master可配置多個Slave節點
  • Master間通過PING監測健康狀態
  • 客戶端可訪問任意節點,自動路由到正確節點

數據分片機制

哈希槽(Hash Slot)

哈希槽

  • 槽位總數:16384個哈希槽
  • 分配算法:CRC16(key) % 16384
  • 槽位分配:每個Master節點負責一部分槽位
數據路由流程
  1. 客戶端對key進行CRC16校驗
  2. 對16384取模確定槽位
  3. 根據槽位映射找到對應節點
  4. 如果訪問錯誤節點,返回MOVED重定向

面試要點總結

架構演進路徑

單機 → 主從復制 → 哨兵集群 → 分片集群

各架構解決的問題

  • 主從復制:讀寫分離,提升并發讀能力
  • 哨兵機制:自動故障轉移,實現高可用
  • 分片集群:水平擴展,解決存儲和寫入瓶頸

核心技術點

  • 數據同步:全量同步 + 增量同步
  • 故障檢測:心跳機制 + 主客觀下線
  • 數據分片:一致性哈希槽算法
  • 腦裂預防:最小從節點數 + 同步延遲限制

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

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

相關文章

無人機保養指南

定期清潔無人機在使用后容易積累灰塵、沙礫等雜物,需及時清潔。使用軟毛刷或壓縮空氣清除電機、螺旋槳和機身縫隙中的雜質。避免使用濕布直接擦拭電子元件,防止短路。電池維護鋰電池是無人機的核心部件,需避免過度放電或充電。長期存放時應保…

vlm MiniCPM 學習部署實戰

目錄 開源地址: 模型repo下載: 單圖片demo: 多圖推理demo: 論文學習筆記: 部署完整教程: 微調教程: 部署,微調教程,視頻實測 BitCPM4 技術報告 創意&#xff1…

92套畢業相冊PPT模版

致青春某大學同學聚會PPT模版,那些年我們一起走過的歲月PPT模版,某學院某班同學聯誼會PPT模版,匆匆那年PPT模版,青春的紀念冊PPT模版,梔子花開PPT模版,畢業紀念冊PPT模版。 92套畢業相冊PPT模版&#xff1…

爬蟲基礎概念

網絡爬蟲概述 概念 網絡爬蟲(Web Crawler),也稱為網絡蜘蛛(Web Spider)或機器人(Bot),是一種自動化程序,用于系統地瀏覽互聯網并收集網頁信息。它模擬人類瀏覽器行為&…

java8 stream流操作的flatMap

我們來詳細解釋一下 Java 8 Stream API 中的 flatMap 操作。理解 flatMap 的關鍵在于將其與 map 操作進行對比。??核心概念:????map 操作:??作用:將一個流中的每個元素??轉換??為另一個元素(類型可以不同)…

開源UI生態掘金:從Ant Design二次開發到行業專屬組件的技術變現

開源UI生態掘金:從Ant Design二次開發到行業專屬組件的技術變現內容摘要在開源UI生態中,Ant Design作為一款廣受歡迎的UI框架,為開發者提供了強大的基礎組件。然而,面對不同行業的特定需求,僅僅依靠現有的組件往往難以…

Object Sense (OSE):一款從編輯器腳本發展起來的編程語言

引言:從Vim編輯器走出的語言在編程語言的世界里,許多革命性的創新往往源于看似簡單的工具。Object Sense(簡稱OSE)的誕生,便與一款經典文本編輯器——Vim息息相關。它的前身是Vim的腳本語言VimL(Vimscript&…

我考PostgreSQL中級專家證書二三事

1. 為什么選擇PGCE?PostgreSQL的開源特性、高性能和高擴展性早已讓我心生向往,而PGCE認證不僅是對技術能力的認可,更是一張通往更高職業舞臺的“通行證”。官方資料提到,PGCE考試涵蓋性能優化、高可用架構、復雜查詢處理、內核原理…

Java 動態導出 Word 登記表:多人員、分頁、動態表格的最佳實踐

本文詳細講解如何使用 Java 動態導出包含多人員報名表的 Word 文檔,每人占據獨立一頁,并支持動態表格行(如個人經歷)。我們對比了多種實現方案,最終推薦基于 Freemarker XML 模板 或 docx4j 的靈活方式,并…

【element-ui el-table】多選表格勾選時默認勾選了全部,row-key綁定異常問題解決

項目場景: Element-UI的el-table組件row-key使用問題 同一個頁面使用了幾個table,這幾個table都使用了多選,row-key屬性,其中row-key的綁定方式都是用的靜態綁定,row-key“username”或row-key“id”,可正常…

C#注釋技巧與基礎編程示例

以下是一個包含基礎注釋的 C# 程序示例&#xff0c;展示了 C# 中各類注釋的使用方法&#xff1a;using System;namespace BasicCSharpProgram {/// <summary>/// Program 類是應用程序的入口點/// 包含 Main 方法作為程序執行的起點/// </summary>public class Pro…

極客大挑戰2019-HTTP

涵蓋知識&#xff1a;UA頭偽造漏洞&#xff1a;全稱&#xff1a;User-Agent 這個部分包含我們所使用的操作系統版本&#xff0c;cpu&#xff0c;瀏覽器類型等。來源偽造漏洞&#xff1a;在http請求頭中會攜帶一個Referer&#xff0c;這個用來表示服務器用戶是從哪個地方來的X-F…

談談ArrayList與Vector的理解?

目錄 擴容機制 ArrayList擴容源碼 Vector擴容源碼 二者區別 擴展&#xff1a;stack(棧&#xff09; 1.創建stack對象 2. 入棧(先進后出&#xff09; 3.出棧 擴展&#xff1a;舉個例子&#xff1a;實現下字符串逆置&#xff0c;利用stack棧來實現。 從接口實現上&#xff…

【Linux庖丁解牛】— 多線程同步 !

1. 什么是線程同步為什么會有線程同步&#xff0c;那一定是有了新問題。互斥可以解決臨界資源被同時訪問的問題&#xff0c;但是純互斥也會帶來新的問題。由于當前被執行的線程離cpu最近【其他線程被阻塞掛起還要被喚醒】&#xff0c;所以&#xff0c;當前進程對于競爭鎖天然就…

基于arduino uno r3主控的環境監測系統設計-1

準備設計arduino uno r3為主控的環境監測系統&#xff0c;通過傳感器采集TVOC&#xff08;總揮發性有機物&#xff09;、HCHO&#xff08;甲醛&#xff09;和eCO2&#xff08;等效二氧化碳&#xff09;數據&#xff0c;并顯示在LCD屏幕上&#xff0c;同時支持數據記錄到SD卡&am…

ITIL 4:云計算與微服務對組織架構的影響

這幾年&#xff0c;很多組織在推進數字化轉型時遇到一個共同的問題&#xff1a;業務節奏越來越快&#xff0c;但內部協作的“架構”卻越來越跟不上節奏。技術架構的變革&#xff0c;必須同步推動組織架構的重塑。特別是隨著云計算和微服務架構的廣泛應用&#xff0c;這種影響愈…

【Android】xml和Java兩種方式實現發送郵件頁面

三三要成為安卓糕手 一&#xff1a;xml中LinearLayout布局參數的使用 1&#xff1a;xml代碼 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:app"http:/…

美林數據用大模型重構電能質量評估,讓隱蔽合規問題無所遁形

在“雙碳”目標驅動下&#xff0c;電網企業正加速推進數字化轉型&#xff0c;電能質量評估作為電力系統安全運行的核心環節&#xff0c;其合規性與效率直接影響著電網智能化水平。然而&#xff0c;傳統人工審核模式已難以應對海量報告與復雜標準——單份報告需20-30人天核對、關…

前端基礎 JS Vue3 Ajax

一、JSalert( .... ) //彈出框console.log( ....... ) //輸出到控制臺瀏覽器JS引入方式&#xff1a;1、內部腳本&#xff1a;將JS代碼定義在HTML頁面中位于<script></script>標簽之間2、外部腳本&#xff1a;將JS代碼寫在外部JS文件中&#xff0c;在HTML頁面中使用…

如何解決pip安裝報錯ModuleNotFoundError: No module named ‘notebook’問題

【Python系列Bug修復PyCharm控制臺pip install報錯】如何解決pip安裝報錯ModuleNotFoundError: No module named ‘notebook’問題 一、摘要 在使用 PyCharm 進行 Python 開發時&#xff0c;常常需要通過 pip install 安裝第三方包。但有時即便已經安裝成功&#xff0c;運行代…