-
Redis高可用解决方案:哨兵(Sentinel)
正文
哨兵是Redis的高可用解决方案:由多个哨兵组成的系统监视主从服务器,可以将下线的主服务器属下的某个从服
务器升级为新的主服务器,继续保障运行。
启动并初始化Sentinel
redis-sentinel /path/to/your/sentinel.conf
Sentinel本质是一个Redis服务器,但是它不会载入RDB or AOF文件。
选举领头Sentinel
当主服务器被判断为客观下线时,监视这个主服务器的哨兵会进行协商,选举一个领头哨兵,由领头哨兵,对下线
的主服务器执行故障转移操作。
-
所有监控这个 主 的在线哨兵都有资格成为领头哨兵。
-
每次进行领头哨兵选举之后,不论选举是否成功,所有哨兵的配置纪元的值会自增一次。配置纪元实际上是一
个计数器,毫无特别。
-
在一个配置纪元里,所有哨兵都有一次将某个哨兵设置为局部领头哨兵的机会,并且局部领头一旦设置,在这个配置纪元里不能再更改。
-
每个哨兵都会要求其他哨兵将自己设置为局部领头。
-
哨兵设置局部领头的规则是先到先得。
-
如果有某个哨兵被半数以上的哨兵设置成了局部领头,这个哨兵成为领头哨兵。
-
在给定时限内,直到选出领头哨兵为止。
故障转移
选举产生领头哨兵后,领头执行故障转移操作:
-
在下线主的从服务器里,挑选一个成为主服务器。
-
让其他从服务器改为复制新的主服务器。
-
下线的主服务器成为从服务器。
选出新的主服务器
新主服务器是怎样炼成的
领头哨兵会按照规则进行过滤:
删除断线的从服务器。
删除最近五秒没有回复领头的从服务器。
保留数据比较新的从服务器。
最后就选择offset最大,运行ID最小的从服务器。
来源:https://www.cnblogs.com/bllbl/p/15354908.html