• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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的使用的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • 浅析Redis Sentinel 与 Redis Cluster
    • 基于SpringCloud手写一个简易版Sentinel
    • Spring Cloud Alibaba之Sentinel实现熔断限流功能
    • Sentinel实现动态配置的集群流控的方法
    • 解决redis sentinel 频繁主备切换的问题
    • Redis Sentinel的基本搭建
    • Spring Cloud Alibaba 使用 Feign+Sentinel 完成熔断的示例
    • Java之SpringCloudAlibaba Sentinel组件案例讲解
    上一篇:Redis Sentinel的基本搭建
    下一篇:redis如何后台启动的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Redis Sentinel的使用方法 Redis,Sentinel,的,使用方法,