虽然现在使用哨兵+主从的方式比较少了,但通过理解 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/)
更多请关注微信公众号【编程不离宗】,专注于分享服务器开发与编程相关的技术干货:

宗离
523 声望484 粉丝

路漫漫其修远兮,吾将上下而求索。