bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

RedisSentinel哨兵模式的原理及配置

這篇文章主要介紹“redis Sentinel哨兵模式的原理及配置”,在日常操作中,相信很多人在Redis Sentinel哨兵模式的原理及配置問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Redis Sentinel哨兵模式的原理及配置”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

10年積累的網站設計、做網站經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站設計后付款的網站建設流程,更有寧強免費網站建設讓你可以放心的選擇與我們合作。


一.安裝配置
在1個master 1個slave 的環境中加一個sentinel,
進入redis源碼安裝目錄copy sentinel.conf文件
# cd /u01/packages/redis-3.0.6
# cp sentinel.conf   /usr/local/redis/etc/
# vi /usr/local/redis/etc/sentinel.conf
daemonize yes
sentinel monitor mymaster 127.0.0.1 6379 1
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 180000

參數解釋:
sentinel monitor mymaster 127.0.0.1 6379 1
指示 Sentinel 去監視一個被命名為 mymaster 的master,可指定為任何名字
Master  IP為127.0.0.1 , 端口號為 6379 ,
這個master判斷為失效至少需要 1 個 Sentinel 同意 (只要同意 Sentinel 的數量不達標,自動故障遷移就不會執行)
注意,無論你設置多少個 Sentinel 同意才能判斷一個服務器失效, 一個 Sentinel 都需要獲得系統中多數(majority) Sentinel 的支持, 才能發起一次自動故障遷移

sentinel down-after-milliseconds mymaster 30000
down-after-milliseconds 指定了 Sentinel 認為master已經斷線所需的毫秒數

sentinel parallel-syncs mymaster 1
parallel-syncs 指定了在執行故障轉移時, 最多可以有多少個slave同時對新的master進行同步, 這個數字越小, 完成故障轉移所需的時間就越長

sentinel failover-timeout mymaster 180000
failover-timeout 指定故障切換允許的毫秒數,超過這個時間,就認為故障切換失敗,默認為3分鐘

啟動sentinel
# redis-sentinel /usr/local/redis/etc/sentinel.conf

查看狀態
# redis-cli -p 26379
127.0.0.1:26379> info sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=mymaster,status=ok,address=127.0.0.1:6379,slaves=1,sentinels=1

至此,配置sentinel工作完成

Sentinel 相關命令
? INFO sentinel的基本狀態信息
? PING :返回 PONG 
? SENTINEL masters :列出所有被監視的master,以及這些master的當前狀態
? SENTINEL slaves <master name> :列出給定master的所有slave服務器,以及這些slave的當前狀態
? SENTINEL get-master-addr-by-name <master name> : 返回給定名字的master的 IP 地址和端口號。 如果這個master正在執行故障轉移操作, 或者針對這個master的故障轉移操作已經完成, 那么這個命令返回新的master的 IP 地址和端口號。
? SENTINEL reset <pattern> : 重置所有名字和給定模式 pattern 相匹配的master。 pattern 參數是一個 Glob 風格的模式。 重置操作清除master目前的所有狀態, 包括正在執行中的故障轉移, 并移除目前已經發現和關聯的,master的所有slave和 Sentinel
? SENTINEL failover <master name> : 當master失效時, 在不詢問其他 Sentinel 意見的情況下, 強制開始一次自動故障遷移 (不過發起故障轉移的 Sentinel 會向其他 Sentinel 發送一個新的配置,其他 Sentinel 會根據這個配置進行相應的更新)。

二. 原理:
故障轉移時主要是解決兩個問題,一是選Leader Sentinel,二是選新的master

1.選Leader Sentinel規則

Sentinel 自動故障遷移使用 Raft 算法來選舉領頭(Leader)Sentinel , 從而確保在一個給定的紀元時期(epoch)里, 只有一個Leader產生。
表示在同一個時期, 不會有兩個 Sentinel 同時被選中為Leader, 并且各個 Sentinel 在同一個時期中只會對一個Leader進行投票。

注:Raft算法主要思想是同一期Term(Epoch)投票中少數服從多數原則達成一致,選出Leader
具體算法這里不過多解釋,詳細可參考文章: https://www.jianshu.com/p/8e4bbe7e276c

 

2.選新master規則
1> 在失效主服務器屬下的從服務器當中, 那些被標記為主觀下線、已斷線、或者最后一次回復 PING 命令的時間大于五秒鐘的從服務器都會被淘汰。
2> 在失效主服務器屬下的從服務器當中, 那些與失效主服務器連接斷開的時長超過 down-after 選項指定的時長十倍的從服務器都會被淘汰。
3> 在經歷了以上兩輪淘汰之后剩下來的從服務器中, 我們選出復制偏移量(replication offset)最大的那個slave作為新的master服務器; 如果復制偏移量不可用, 或者slave服務器的復制偏移量相同, 那么帶有最小運行 ID 的那個從服務器成為新的master。

一次故障轉移步驟:
1>發現master已進入客觀下線狀態。
2>對當前紀元時期(epoch)進行自增, 并嘗試在這個紀元時期中當選。
3>如果當選失敗, 那么在設定的故障遷移超時時間的兩倍之后, 重新嘗試當選。 如果當選成功, 那么執行以下步驟
4>選出一個slave,并將它升級為master。
5>向被選中的slave發送 SLAVEOF NO ONE 命令,讓它轉變為master。
通過發布與訂閱功能, 將更新后的配置傳播給所有其他 Sentinel , 其他 Sentinel 對它們自己的配置進行更新。
6>向已下線master的其它slave發送 SLAVEOF host port 命令, 讓它們去復制新的master。
7>當所有slave都已經開始復制新的master時, 領頭 Sentinel 終止這次故障遷移操作。

到此,關于“Redis Sentinel哨兵模式的原理及配置”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注創新互聯網站,小編會繼續努力為大家帶來更多實用的文章!

分享文章:RedisSentinel哨兵模式的原理及配置
路徑分享:http://vcdvsql.cn/article4/gjgiie.html

成都網站建設公司_創新互聯,為您提供自適應網站網站營銷靜態網站全網營銷推廣網站收錄網站策劃

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都app開發公司