redis的哨兵集群
2019-11-03 21:00:00 0 举报
redis的哨兵集群
作者其他创作
大纲/内容
哨兵1
非首次:复制node缺少的数据
backlog
自己的host、ip和runid
slave node3
is-master-down-after-milliseconds超时
启动:发送PSYNC命令
Redis的同步原理及哨兵机制
ping master
生成RDB快照
哨兵2
删除过期key
从本地磁盘加载到内存中
ping master超时:master sdown(主观宕机)
slave node2
第一次连接full resynchronization
过期key
每次一个哨兵要做主备切换,首先需要quorum数量的哨兵认为odown,然后选举出一个哨兵来做切换,这个哨兵还得得到majority哨兵的授权,才能正式执行切换;如果quorum < majority,比如5个哨兵,majority就是3,quorum设置为2,那么就3个哨兵授权就可以执行切换但是如果quorum >= majority,那么必须quorum数量的哨兵都授权,比如5个哨兵,quorum是5,那么必须5个哨兵都同意授权,才能执行切换
master node
slave node1
__sentinel__:hello channel
ping
模拟一条del命令发送给slave
内存
本地磁盘
ping超时
哨兵3
网络断联:自动重连
master节点的选取机制:(1)跟master断开连接的时长(2)slave优先级(3)复制offset(4)run id如果一个slave跟master断开连接已经超过了down-after-milliseconds的10倍,外加master宕机的时长,那么slave就被认为不适合选举为master(1)按照slave优先级进行排序,slave priority越低,优先级就越高(2)如果slave priority相同,那么看replica offset,哪个slave复制了越多的数据,offset越靠后,优先级就越高(3)如果上面两个条件都相同,那么选择一个run id比较小的那个slave
slave将同步的RDB写入磁盘
发送到slave
保存master idreplica offset
0 条评论
下一页