阅读 55

Redis高可用解决方案:哨兵(Sentinel)

哨兵是Redis的高可用解决方案:由多个哨兵组成的系统监视主从服务器,可以将下线的主服务器属下的某个从服

务器升级为新的主服务器,继续保障运行。

启动并初始化Sentinel

redis-sentinel /path/to/your/sentinel.conf

Sentinel本质是一个Redis服务器,但是它不会载入RDB or AOF文件。

...

选举领头Sentinel

当主服务器被判断为客观下线时,监视这个主服务器的哨兵会进行协商,选举一个领头哨兵,由领头哨兵,对下线

的主服务器执行故障转移操作。

  1. 所有监控这个 主 的在线哨兵都有资格成为领头哨兵。

  2. 每次进行领头哨兵选举之后,不论选举是否成功,所有哨兵的配置纪元的值会自增一次。配置纪元实际上是一

    个计数器,毫无特别。

  3. 在一个配置纪元里,所有哨兵都有一次将某个哨兵设置为局部领头哨兵的机会,并且局部领头一旦设置,在这个配置纪元里不能再更改。

  4. 每个哨兵都会要求其他哨兵将自己设置为局部领头。

  5. 哨兵设置局部领头的规则是先到先得。

  6. 如果有某个哨兵被半数以上的哨兵设置成了局部领头,这个哨兵成为领头哨兵。

  7. 在给定时限内,直到选出领头哨兵为止。

故障转移

选举产生领头哨兵后,领头执行故障转移操作:

  1. 在下线主的从服务器里,挑选一个成为主服务器。

  2. 让其他从服务器改为复制新的主服务器。

  3. 下线的主服务器成为从服务器。

选出新的主服务器

新主服务器是怎样炼成的

领头哨兵会按照规则进行过滤:

  1. 删除断线的从服务器。
  2. 删除最近五秒没有回复领头的从服务器。
  3. 保留数据比较新的从服务器。
  4. 最后就选择offset最大,运行ID最小的从服务器。

Reference

《Redis设计与实现》

原文:https://www.cnblogs.com/bllbl/p/15354908.html

文章分类
百科问答
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐