虽然现在使用哨兵+主从的方式比较少了,但通过理解 Redis 哨兵,我们能获得更深入的分布式的知识。
sentinel基本配置
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和其副本的自动发现
sentinel和其副本的自动发现,采用了 Pub/Sub发布订阅机制实现
- 1.每个sentinel每2秒往其监视的Redis Master及其副本中发布频道
__sentinel__:hello
宣告自己的 ip port runid - 2.每个sentinel都订阅其监视的Redis Master及其副本中的频道
__sentinel__:hello
@SvenAugustus(https://www.flysium.xyz/)
更多请关注微信公众号【编程不离宗】,专注于分享服务器开发与编程相关的技术干货: