搜尋
首頁資料庫Redis怎麼解析Redis中的哨兵模式原理

這篇文章帶大家深入理解下Redis哨兵模式原理,聊聊sentinel能幹什麼,啟動sentinel方法和Sentinel工作流程,希望對大家有所幫助!

一、Redis sentinel是什麼?

Redis Sentinel是Redis官方提供的解決方案,用於實現高可用性。 Redis Sentinel為Redis提供高可用性。實際上,這意味著使用Sentinel可以創建一個Redis集群,在沒有人為幹預的情況下抵抗某些類型的失敗,自動實現故障轉移。 【相關推薦:Redis影片教學】

二、sentinel能做什麼?

1、監控redis叢集節點(master replica)和sentinel節點健康狀態

2、自動故障轉移:如果master故障,sentinel可以實現故障轉移,並且通知客戶端連接新的master。

3、通知:透過api,可以發送通知到管理員,開發人員,監控的redis實例出現了故障

4、配置中心:客戶端連接到sentinel,sentinel可以訪問master將節點資訊回傳給客戶端

三、啟動sentinel方法

1、redis-sentinel /path/to/sentinel.conf

## 2、redis-server /path/to/sentinel.conf --sentinel

sentinel.conf設定說明如下

# 配置需要监控的master节点信息 2代表法定人数 作用是表示需要最少需要多少个sentinel节点同意
#master节点不可达才标记为客观下线
#举例 5个sentinel实例 quorum设置成2 那么有2个sentinel节点认为master不可达,
#则其中一个会启动故障转移#如果至少有三个哨兵可到达,故障转移将被授权并实际启动。
sentinel monitor mymaster 127.0.0.1 6379 2 
#只需要配置master sentinel会自动检测slave信息
sentinel down-after-milliseconds mymaster 60000 
#如果master在指定时间内没有响应ping命令/或报错,则认为主观下线了。
sentinel failover-timeout mymaster 180000
sentinel parallel-syncs mymaster 1 
#指定故障转移的时候,同时支持多少个replica并行的与master同步数据,越小故障转移越久
#以上配置可以通过SENTINEL SET command.来实时修改。
sentinel monitor resque 192.168.1.3 6380 4
sentinel down-after-milliseconds resque 10000
sentinel failover-timeout resque 180000
sentinel parallel-syncs resque 5

注意點:

Redis-sentinel必須使用設定文件啟動,重啟需要根據配置文件恢復,預設打開26379端口,sentinel之間必須開放端口訪問,方便相互訪問。

四、Sentinel工作流程

1、首先sentinel之間是透過redis的pub/subscribe機制實現動態感知。

怎麼解析Redis中的哨兵模式原理怎麼解析Redis中的哨兵模式原理

客觀下線:

當主觀下線的節點是主節點時,哨兵節點會透過指令 sentinel is-masterdown-by-addr尋求其它哨兵節點對主節點的判斷,當超過quorum(在sentinel配置中配置的法定人數)個數,此時哨兵節點則認為該主節點確實有問題,這樣就客觀下線了,大部分哨兵節點都同意下線操作,也就說是客觀下線。

注意客觀下線只針對master節點生效,它會觸發故障轉移

3,master下線了,需要進行故障轉移

這裡又分為兩步,首先需要選擇sentinel哨兵主節點,透過sentinel主節點來進行redis的故障轉移。

首先是sentinel選舉領導者。使用raft演算法(狀態共識演算法)。

每一個Sentinel節點都可以成為Leader,當一個Sentinel節點確認redis集群的主節點主觀下線後,會請求其他Sentinel節點要求將自己選舉為Leader。被請求的Sentinel節點如果沒有同意其他Sentinel節點的選舉請求,則同意該請求(選舉票數 1),否則不同意。

如果一個Sentinel節點所獲得的選舉票數達到Leader最低票數(quorum和Sentinel節點數/2 1的最大值),則該Sentinel節點選舉為Leader;否則重新進行選舉。

Raft核心思想:先到先得,少數服從多數。

sentinel選出主節點後,sentinel主節點需要選出redis群集主節點,建構新的群集關係。

選出新redis主節點的依據是:

1、與sentinel斷開連線的時間。過濾發現與主sentinel伺服器斷開連線的時間超過配置的主機逾時時間down-after-milliseconds的副本slaves

2、副本優先權。優先選擇replica-priority低的。

3、如果優先權相同,已處理複製偏移量。越大越優先,這個更符合業務場景功能。

4、如果複製offset相同,就看運行ID。優先選擇小的。

選擇出master節點後,開始維護叢集關係。

1、sentinel節點,向新主節點發送,slave no one命令,讓它成為獨立節點

2、sentinel節點,向其他節點發送slaveof ip port,跟隨到主節點

五、總結

透過上面的分析,sentinel透過定時監控手段,可以實現自動故障轉移,不過sentinel還是有一些問題,例如單一master節點情況下,資料存在遺失的可能,如果單機效能有限,也沒有橫向擴展的能力。

以上是怎麼解析Redis中的哨兵模式原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
REDIS與SQL數據庫:關鍵差異REDIS與SQL數據庫:關鍵差異Apr 25, 2025 am 12:02 AM

Redis和SQL數據庫的主要區別在於:Redis是內存數據庫,適用於高性能和靈活性需求;SQL數據庫是關係型數據庫,適用於復雜查詢和數據一致性需求。具體來說,1)Redis提供高速數據訪問和緩存服務,支持多種數據類型,適用於緩存和實時數據處理;2)SQL數據庫通過表格結構管理數據,支持複雜查詢和事務處理,適用於電商和金融系統等需要數據一致性的場景。

REDIS:它如何充當數據存儲和服務REDIS:它如何充當數據存儲和服務Apr 24, 2025 am 12:08 AM

REDISACTSASBOTHADATASTOREANDASERVICE.1)ASADATASTORE,ITUSESIN-MEMORYSTOOGATOFORFOFFASTESITION,支持VariousDatharptructuresLikeKey-valuepairsandsortedsetsetsetsetsetsetsets.2)asaservice,ItprovidespunctionslikeItionitionslikepunikeLikePublikePublikePlikePlikePlikeAndluikeAndluAascriptingiationsmpleplepleclexplectiations

REDIS與其他數據庫:比較分析REDIS與其他數據庫:比較分析Apr 23, 2025 am 12:16 AM

Redis與其他數據庫相比,具有以下獨特優勢:1)速度極快,讀寫操作通常在微秒級別;2)支持豐富的數據結構和操作;3)靈活的使用場景,如緩存、計數器和發布訂閱。選擇Redis還是其他數據庫需根據具體需求和場景,Redis在高性能、低延遲應用中表現出色。

REDIS的角色:探索數據存儲和管理功能REDIS的角色:探索數據存儲和管理功能Apr 22, 2025 am 12:10 AM

Redis在數據存儲和管理中扮演著關鍵角色,通過其多種數據結構和持久化機製成為現代應用的核心。 1)Redis支持字符串、列表、集合、有序集合和哈希表等數據結構,適用於緩存和復雜業務邏輯。 2)通過RDB和AOF兩種持久化方式,Redis確保數據的可靠存儲和快速恢復。

REDIS:了解NOSQL概念REDIS:了解NOSQL概念Apr 21, 2025 am 12:04 AM

Redis是一種NoSQL數據庫,適用於大規模數據的高效存儲和訪問。 1.Redis是開源的內存數據結構存儲系統,支持多種數據結構。 2.它提供極快的讀寫速度,適合緩存、會話管理等。 3.Redis支持持久化,通過RDB和AOF方式確保數據安全。 4.使用示例包括基本的鍵值對操作和高級的集合去重功能。 5.常見錯誤包括連接問題、數據類型不匹配和內存溢出,需注意調試。 6.性能優化建議包括選擇合適的數據結構和設置內存淘汰策略。

REDIS:現實世界的用例和示例REDIS:現實世界的用例和示例Apr 20, 2025 am 12:06 AM

Redis在現實世界中的應用包括:1.作為緩存系統加速數據庫查詢,2.存儲Web應用的會話數據,3.實現實時排行榜,4.作為消息隊列簡化消息傳遞。 Redis的多功能性和高性能使其在這些場景中大放異彩。

REDIS:探索其功能和功能REDIS:探索其功能和功能Apr 19, 2025 am 12:04 AM

Redis脫穎而出是因為其高速、多功能性和豐富的數據結構。 1)Redis支持字符串、列表、集合、散列和有序集合等數據結構。 2)它通過內存存儲數據,支持RDB和AOF持久化。 3)從Redis6.0開始引入多線程處理I/O操作,提升了高並發場景下的性能。

Redis是SQL還是NOSQL數據庫?答案解釋了Redis是SQL還是NOSQL數據庫?答案解釋了Apr 18, 2025 am 12:11 AM

RedisisclassifiedasaNoSQLdatabasebecauseitusesakey-valuedatamodelinsteadofthetraditionalrelationaldatabasemodel.Itoffersspeedandflexibility,makingitidealforreal-timeapplicationsandcaching,butitmaynotbesuitableforscenariosrequiringstrictdataintegrityo

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)