哨兵模式是通过哨兵节点完成对数据节点的监控、下线、故障服务器托管网转移。
定时监控
Redis Sentinel通过三个定时监控任务完成对各个节点发现和监控:
1. 每隔10秒,每个Sentinel节点会向主节点和从节点发送info命令获取最新的拓扑结构
2. 每隔2秒,每个Sentinel节点会向Redis数据节点的sentinel :hello 频道上发送该Sentinel节点对于主节点的判断以及当前Sentinel节点的信息
3. 每隔1秒,每个Sentinel节点会向主节点、从节点、其余Sentinel节点发送一条ping命令做一次心跳检测,来确认这些节点当前是否可达
主观下线和客观下线
1. 主观下线
每个Sentinel节点会每隔1秒对主节点、从节点、其他Sentinel节点发送ping命令做心跳检测,当这些节点超过 down-after-milliseconds没有进行有效回复,Sentinel节点就会对该节点做失败判定,这个行为叫做主观下线。
2. 客观下线
当Sentinel主观下线的节点是主节点时,该Sentinel节点会通过sentinel is- masterdown-by-addr命令向其他Sentinel节点询问对主节点的判断,当超过 个数,Sentinel节点认服务器托管网为主节点确实有问题,这时该Sentinel节点会做出客观下线的决定线就是哨兵节点认为某个节点有问题,客观下线就是超过一定数量的哨兵节点认为主节点有问题。
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
一、背景 时间大概是在夏天7月份,突然收到小伙伴的情报,我们线上的一个kafka实例的某个broker突然不提供服务了,也没看到什么异常日志,反正就是生产、消费都停了。因为是线上服务,而且进程还在,就是不提供服务了,第一反应就是保留一下 stack 信息,先重…