這篇文章帶大家深入理解下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機制實現動態感知。
客觀下線:
當主觀下線的節點是主節點時,哨兵節點會透過指令 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中文網其他相關文章!

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

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

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

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

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

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

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

RedisisclassifiedasaNoSQLdatabasebecauseitusesakey-valuedatamodelinsteadofthetraditionalrelationaldatabasemodel.Itoffersspeedandflexibility,makingitidealforreal-timeapplicationsandcaching,butitmaynotbesuitableforscenariosrequiringstrictdataintegrityo


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

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

Dreamweaver CS6
視覺化網頁開發工具

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

SublimeText3 Linux新版
SublimeText3 Linux最新版

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