虽然现在使用哨兵+主从的方式比较少了,但通过理解 Redis 哨兵,我们能获得更深入的分布式的知识。
sentinel的作用:
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和其副本的自动发现,采用了 Pub/Sub发布订阅机制实现
__sentinel__:hello
宣告自己的 ip port runid __sentinel__:hello