欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis Sentinel的使用方法

 更新時間:2021年03月30日 11:54:38   作者:AsiaYe  
這篇文章主要介紹了Redis Sentinel的使用方法,幫助大家更好的理解和學習使用Redis數據庫,感興趣的朋友可以了解下

1、sentinel monitor

用法:

sentinel monitor master-name  ip port quorum

其中,master-name是主節(jié)點的名稱,ip,port不用解釋,是主節(jié)點的地址信息。

   最后的quorum是判斷主節(jié)點最終不可達所需要的票數。這個值越大,判斷越可信,這個值越小,判斷越不可信,一般這個數字取的是sentinel節(jié)點數目的一半+1.同時,該值還與sentinel節(jié)點的領導者選舉有關,至少要有max(quorum,num (sentinel)/2+1)個節(jié)點參與選舉,才能選出領導者sentinel,從而完成故障轉換。例如有5個sentinel節(jié)點,quorum設置為4,那么num(sentinel)/2+1=3,max函數返回4,最少要有4個節(jié)點才可以進行領導者選舉。

2、sentinel  down-after-milliseconds 

用法如下:

sentinel  down-after-milliseconds master-name  times

該參數表示超過了配置的時間,沒有收到有效的回復,則判斷sentinel節(jié)點不可達,其中time的單位是毫秒。其中master-name為sentinel節(jié)點的名稱。

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對一個主節(jié)點的額故障轉移失敗,那么下次在對該主節(jié)點做故障轉移的起始時間是FT的2倍

b、對于新選出來的主節(jié)點,執(zhí)行slaveof no one的時候(因為原來它是個從庫),如果出現失敗,當超過FT時,則故障轉移失敗。

c、選出新的主節(jié)點后,redis會在新主節(jié)點上執(zhí)行info命令,如果執(zhí)行時間超過FT時,則故障轉移失敗

d、如果其余從節(jié)點和新的主節(jié)點,在重新建立復制關系的時候,如果超過了FT的時間,那么故障轉移失敗。

5、sentinel auth-pass

用法:

sentinel auto-pass master-name password

從節(jié)點sentinel上配置主節(jié)點的密碼,從而保證可以和主節(jié)點進行通信

6、sentinel notification-scripts

用法:

sentinel notification-scripts master-name scripts-path

7、sentinel client-reconfig-scripts

用法:

sentinel client-reconfig-scripts master-name scripts-path

 在故障轉移結束后,會觸發(fā)對應路徑的腳本,并向腳本發(fā)送故障轉移結果的相關參數。例如配置郵件或者報警。

參數6和參數7中需要注意,配置的腳本必須有執(zhí)行權限,同時必須包含shell腳本頭,腳本的最大執(zhí)行時間不能超過60s,不過在一般的線上環(huán)境,通常不會用這個參數來配置相關腳本。

Redis Sentinel同時監(jiān)控多個Redis節(jié)點

   這個還是比較簡單的,只需要在sentinel的配置文件中寫上多個節(jié)點的名稱,其他參數也區(qū)分開來即可。例如:

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 動態(tài)配置調整

   我們可以使用sentinel set param value的方法來動態(tài)的設置sentinel的參數,這里有幾點需要注意:

1、sentinel set命令只對當前sentinel節(jié)點有效

2、sentinel set命令如果執(zhí)行成功,會立即刷新配置文件,而不需要我們手動config rewrite

3、建議所有sentinel節(jié)點的配置盡可能一致,可以提高故障轉移的有效性

4、sentinel對外不支持config命令

Redis Sentinel部署原則

a、sentinel節(jié)點不應該部署在一臺物理機器上。這個比較容易理解

b、部署至少三個且奇數個sentinel節(jié)點。注意,這里的奇數個不是為了投票,而是因為偶數個和奇數個的投票效果一致,奇數個可以節(jié)省一個節(jié)點。

c、有條件的情況下,盡量使用sentinel節(jié)點和redis節(jié)點一對一的方式部署,不要使用同一套sentinel來管理多個redis主節(jié)點。

相關的sentinel API:

1、sentinel masters

展示所有被監(jiān)控的主節(jié)點狀態(tài)以及相關的統(tǒng)計信息

[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的主節(jié)點狀態(tài)以及相關的統(tǒng)計信息

3、sentinel slaves master-name

展示指定master-name的從節(jié)點狀態(tài)以及相關統(tǒng)計信息

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節(jié)點集合,不包含當前sentinel節(jié)點。

5、sentinel get-master-addr-by-name master-name

返回指定master-name的主節(jié)點的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通配符風格的主節(jié)點配置進行重置,包含清除主節(jié)點的相關狀態(tài),重新發(fā)現從節(jié)點和sentinel節(jié)點等

7、sentinel failover master-name

 對指定<master-name>的主節(jié)點進行強制故障轉移,該命令在redis的日常運維中非常有用。

8、sentinel ckquorum  master-name

檢測當前可達的sentinel節(jié)點總數是否達到了quorum的個數,例如quorum的值為3,而當前的可達的sentinel節(jié)點個數為2,則無法進行故障轉移,redis sentinel的高可用特性也將失去

9、sentinel flushconfig

將sentinel節(jié)點的配置強制刷到磁盤上,這個命令sentinel節(jié)點自身用的比較多,當配置文件丟失或者損壞時,該命令比較有用。

10、sentinel remove master-name

取消當前redis sentinel節(jié)點對于指定master-name主節(jié)點的監(jiān)控。

11、sentinel monitor master-name ip port quorum

這個命令和配置文件中的配置是一樣的,都是為了監(jiān)控主節(jié)點。只不過這個是通過命令的形式監(jiān)控的。

12、sentinel set master-name

動態(tài)修改sentinel節(jié)點的配置選項

13、sentinel is-master-down-by-addr

sentinel節(jié)點之間用來交換對主節(jié)點是否下線的判斷,根據參數的不同,可以作為sentinel領導者選舉的通信方式。

以上就是Redis Sentinel的使用方法的詳細內容,更多關于Redis Sentinel的使用的資料請關注腳本之家其它相關文章!

相關文章

  • Redis常用命令集的使用

    Redis常用命令集的使用

    作為一名Redis開發(fā)者或管理員,熟練掌握Redis的常用命令是必不可少的,本文主要介紹了Redis常用命令集的使用,具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-11-11
  • Redis持久化方式之RDB和AOF的原理及優(yōu)缺點

    Redis持久化方式之RDB和AOF的原理及優(yōu)缺點

    在Redis中,數據可以分為兩類,即內存數據和磁盤數據,Redis?提供了兩種不同的持久化方式,其中?RDB?是快照備份機制,AOF?則是追加寫操作機制,本文將詳細給大家介紹Redis?持久化方式RDB和AOF的原理及優(yōu)缺點,感興趣的同學可以跟著小編一起來學習
    2023-06-06
  • Redis操作相關命令之查看、停止、啟動命令

    Redis操作相關命令之查看、停止、啟動命令

    這篇文章主要介紹了Redis操作相關命令之查看、停止、啟動命令,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 淺談RedisTemplate和StringRedisTemplate的區(qū)別

    淺談RedisTemplate和StringRedisTemplate的區(qū)別

    本文主要介紹了RedisTemplate和StringRedisTemplate的區(qū)別及個人見解,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Redis實現分布式鎖的實例講解

    Redis實現分布式鎖的實例講解

    在本篇文章里小編給大家整理了一篇關于Redis實現分布式鎖的實例講解內容,有興趣的朋友們可以學習參考下。
    2021-12-12
  • Redis 5.05 單獨模式安裝及配置方法

    Redis 5.05 單獨模式安裝及配置方法

    這篇文章主要介紹了Redis 5.05 單獨模式安裝,文中通過代碼給大家介紹了Redis 5.0.5 單節(jié)點 安裝配置方法,需要的朋友可以參考下
    2019-10-10
  • Redis?SCAN命令詳解

    Redis?SCAN命令詳解

    SCAN 命令是一個基于游標的迭代器,每次被調用之后, 都會向用戶返回一個新的游標, 用戶在下次迭代時需要使用這個新游標作為 SCAN 命令的游標參數, 以此來延續(xù)之前的迭代過程,這篇文章給大家介紹了Redis?SCAN命令的相關知識,感興趣的朋友一起看看吧
    2022-07-07
  • Java實現多級緩存的方法詳解

    Java實現多級緩存的方法詳解

    對于高并發(fā)系統(tǒng)來說,有三個重要的機制來保障其高效運行,它們分別是:緩存、限流和熔斷,所以本文就來和大家探討一下多級緩存的實現方法,希望對大家有所幫助
    2024-02-02
  • redis 用scan指令 代替keys指令(詳解)

    redis 用scan指令 代替keys指令(詳解)

    下面小編就為大家分享一篇redis 用scan指令 代替keys指令詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • Redis內存空間占用及避免數據丟失的方法

    Redis內存空間占用及避免數據丟失的方法

    在現代的互聯網應用中,Redis作為一種高性能的內存數據庫,被廣泛應用于緩存、會話管理和消息隊列等場景,然而,Redis的內存資源是有限的,過多的內存占用可能會導致數據丟失所以本文將給大家介紹一下Redis內存空間占用及避免數據丟失的方法
    2023-08-08

最新評論