• Redis 哨兵机制


    虽然现在使用哨兵+主从的方式比较少了,但通过理解 Redis 哨兵,我们能获得更深入的分布式的知识。

    sentinel基本配置

    file
    sentinel的作用:

    • 1、监控
    • 2、通知
    • 3、自动故障转移 (1.投票决策master是否挂了,如果投票决策master挂了,2.则进一步决策选出执行故障转移的leader, 去执行故障转移)
    • 4、充当client的授权和master查询服务
    sentinel monitor <master-group-name> <ip> <port> <quorum>
    

    quorum 的含义:
    (1)表示 sentinel 集群中 quorum 个节点认为 master挂了,那么就可能触发自动故障转移进程。
    (2)quorum 仅用于故障检测,不涉及sentinel 集群的其他投票决策。

    sentinel <option_name> <master_name> <option_value>
    

    (1)判断主master挂机的时间 down-after-milliseconds
    master没有回复PING或回复错误,这个持续多久了,sentinel节点就可以认为master挂了

    (2)在故障转移后重新配置为使用新Master的副本数 parallel-syncs
    此数越小,故障转移速度越快
    但需要注意的是当副本也提供服务的时候,可能存在不一致数据

    (3)失败的超时时间 failover-timeout
    failover过期时间,当failover开始后,在此时间内仍然没有触发任何failover操作,当前sentinel将会认为此次failoer失败。

    sentinel和其副本的自动发现

    file
    sentinel和其副本的自动发现,采用了 Pub/Sub发布订阅机制实现

    • 1.每个sentinel每2秒往其监视的Redis Master及其副本中发布频道 __sentinel__:hello 宣告自己的 ip port runid
    • 2.每个sentinel都订阅其监视的Redis Master及其副本中的频道 __sentinel__:hello

    @SvenAugustus(https://www.flysium.xyz/)
    更多请关注微信公众号【编程不离宗】,专注于分享服务器开发与编程相关的技术干货:

  • 相关阅读:
    Ugly Numbers
    Present
    Out of Hay
    Stars(树状数组或线段树)
    Humble Numbers
    Wireless Network
    Rank List
    Argus
    食物链
    Antenna Placement
  • 原文地址:https://www.cnblogs.com/svenaugustus/p/12932600.html
Copyright © 2020-2023  润新知