Redis Sentinel的使用方法
1、sentinel monitor
用法:
sentinel monitor master-name ip port quorum
其中,master-name是主節點的名稱,ip,port不用解釋,是主節點的地址信息。
最後的quorum是判斷主節點最終不可達所需要的票數。這個值越大,判斷越可信,這個值越小,判斷越不可信,一般這個數字取的是sentinel節點數目的一半+1.同時,該值還與sentinel節點的領導者選舉有關,至少要有max(quorum,num (sentinel)/2+1)個節點參與選舉,才能選出領導者sentinel,從而完成故障轉換。例如有5個sentinel節點,quorum設置為4,那麼num(sentinel)/2+1=3,max函數返回4,最少要有4個節點才可以進行領導者選舉。
2、sentinel down-after-milliseconds
用法如下:
sentinel down-after-milliseconds master-name times
該參數表示超過瞭配置的時間,沒有收到有效的回復,則判斷sentinel節點不可達,其中time的單位是毫秒。其中master-name為sentinel節點的名稱。
3、sentinel parallel-syncs
用法:
sentinel parallel-syncs master-name nums
4、sentinel failover-timeout
用法:
sentinel failover-timeout master-name times
failover-timeout通常翻譯成故障轉移超時時間(以下簡稱FT),但實際上它作用於故障轉移的各個階段。它的作用:
a、如果redis sentinel對一個主節點的額故障轉移失敗,那麼下次在對該主節點做故障轉移的起始時間是FT的2倍
b、對於新選出來的主節點,執行slaveof no one的時候(因為原來它是個從庫),如果出現失敗,當超過FT時,則故障轉移失敗。
c、選出新的主節點後,redis會在新主節點上執行info命令,如果執行時間超過FT時,則故障轉移失敗
d、如果其餘從節點和新的主節點,在重新建立復制關系的時候,如果超過瞭FT的時間,那麼故障轉移失敗。
5、sentinel auth-pass
用法:
sentinel auto-pass master-name password
從節點sentinel上配置主節點的密碼,從而保證可以和主節點進行通信
6、sentinel notification-scripts
用法:
sentinel notification-scripts master-name scripts-path
7、sentinel client-reconfig-scripts
用法:
sentinel client-reconfig-scripts master-name scripts-path
在故障轉移結束後,會觸發對應路徑的腳本,並向腳本發送故障轉移結果的相關參數。例如配置郵件或者報警。
參數6和參數7中需要註意,配置的腳本必須有執行權限,同時必須包含shell腳本頭,腳本的最大執行時間不能超過60s,不過在一般的線上環境,通常不會用這個參數來配置相關腳本。
Redis Sentinel同時監控多個Redis節點
這個還是比較簡單的,隻需要在sentinel的配置文件中寫上多個節點的名稱,其他參數也區分開來即可。例如:
sentinel monitor node1 IP1 port1 quorum1 sentinel client-reconfig-scripts node1 scripts-path1 -------- sentinel monitor node2 IP2 port2 quorum2 sentinel client-reconfig-scripts node2 scripts-path2
Redis Sentinel 動態配置調整
我們可以使用sentinel set param value的方法來動態的設置sentinel的參數,這裡有幾點需要註意:
1、sentinel set命令隻對當前sentinel節點有效
2、sentinel set命令如果執行成功,會立即刷新配置文件,而不需要我們手動config rewrite
3、建議所有sentinel節點的配置盡可能一致,可以提高故障轉移的有效性
4、sentinel對外不支持config命令
Redis Sentinel部署原則
a、sentinel節點不應該部署在一臺物理機器上。這個比較容易理解
b、部署至少三個且奇數個sentinel節點。註意,這裡的奇數個不是為瞭投票,而是因為偶數個和奇數個的投票效果一致,奇數個可以節省一個節點。
c、有條件的情況下,盡量使用sentinel節點和redis節點一對一的方式部署,不要使用同一套sentinel來管理多個redis主節點。
相關的sentinel API:
1、sentinel masters
展示所有被監控的主節點狀態以及相關的統計信息
[root@VM_48_10_centos ~]# redis-cli -p 26379 127.0.0.1:26379> sentinel masters 1) 1) "name" 2) "mymaster" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6379" 7) "runid" 8) "2ba04c1d8f837f2e419f6f5390c0d5938a6895f4" 9) "flags" 10) "master" 11) "pending-commands" 12) "0" 13) "last-ping-sent" 14) "0" 15) "last-ok-ping-reply" 16) "377" 17) "last-ping-reply" 18) "377" 19) "down-after-milliseconds" 20) "30000" 21) "info-refresh" 22) "8296" 23) "role-reported" 24) "master" 25) "role-reported-time" 26) "170821848" 27) "config-epoch" 28) "0" 29) "num-slaves" 30) "2" 31) "num-other-sentinels" 32) "2" 33) "quorum" 34) "2" 35) "failover-timeout" 36) "180000" 37) "parallel-syncs" 38) "1"
2、sentinel master master-name
展示指定master-name的主節點狀態以及相關的統計信息
3、sentinel slaves master-name
展示指定master-name的從節點狀態以及相關統計信息
127.0.0.1:26379> sentinel slaves mymaster 1) 1) "name" 2) "127.0.0.1:6380" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6380" 7) "runid" ----------------省略------------ 2) 1) "name" 2) "127.0.0.1:6381" 3) "ip" 4) "127.0.0.1" 5) "port" 6) "6381" 7) "runid"
4、sentinel sentinels master-name
展示指定master-name的sentinel節點集合,不包含當前sentinel節點。
5、sentinel get-master-addr-by-name master-name
返回指定master-name的主節點的IP和端口
127.0.0.1:26379> sentinel get-master-addr-by-name mymaster 1) "127.0.0.1" 2) "6379"
6、sentinel reset pattern
sentinel對於符合pattern通配符風格的主節點配置進行重置,包含清除主節點的相關狀態,重新發現從節點和sentinel節點等
7、sentinel failover master-name
對指定<master-name>的主節點進行強制故障轉移,該命令在redis的日常運維中非常有用。
8、sentinel ckquorum master-name
檢測當前可達的sentinel節點總數是否達到瞭quorum的個數,例如quorum的值為3,而當前的可達的sentinel節點個數為2,則無法進行故障轉移,redis sentinel的高可用特性也將失去
9、sentinel flushconfig
將sentinel節點的配置強制刷到磁盤上,這個命令sentinel節點自身用的比較多,當配置文件丟失或者損壞時,該命令比較有用。
10、sentinel remove master-name
取消當前redis sentinel節點對於指定master-name主節點的監控。
11、sentinel monitor master-name ip port quorum
這個命令和配置文件中的配置是一樣的,都是為瞭監控主節點。隻不過這個是通過命令的形式監控的。
12、sentinel set master-name
動態修改sentinel節點的配置選項
13、sentinel is-master-down-by-addr
sentinel節點之間用來交換對主節點是否下線的判斷,根據參數的不同,可以作為sentinel領導者選舉的通信方式。
以上就是Redis Sentinel的使用方法的詳細內容,更多關於Redis Sentinel的使用的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- None Found