sentinal 中文名是哨兵
哨兵是 redis 集群架构中非常重要的一个组件,主要功能如下
哨兵本身也是分布式的,作为一个哨兵集群去运行,互相协同工作
目前采用的是 sentinal 2 版本,相对于 sentinal 1 来说,重写了很多代码,主要是让故障转移的机制和算法变得更加健壮和简单
需要进行充足的测试,可用把生产数据拿过来进行容灾演练
--哨兵集群必须部署 2 个以上节点,如果哨兵集群仅仅部署了个 2 个哨兵实例,且 Configuration: quorum = 1 (只有一个节点投票通过就算选举成功)
+----+ +----+
| M1 |---------| R1 |
| S1 | | S2 |
+----+ +----+
master 宕机,s1 和 s2 中只要有 1 个哨兵认为 master 宕机就可以切换,同时 s1 和 s2 中会选举出一个哨兵来执行故障转移
这个时候,需要 majority,也就是大多数哨兵都是运行的,2 个哨兵的 majority 就是 2(因为至少是 2 个节点以上,2 的 majority=2,3的 majority=2,5 的 majority=3,4 的 majority=2),2 个哨兵都运行着,就可以允许执行故障转移
但是如果整个 M1 和 S1 运行的机器宕机了,那么哨兵只有 1 个了,此时就没有 majority 来允许执行故障转移,虽然另外一台机器还有一个 R1,但是故障转移不会执行
--经典的 3 节点哨兵集群
+----+
| M1 |
| S1 |
+----+
|
+----+ | +----+
| R2 |----+----| R3 |
| S2 | | S3 |
+----+ +----+
Configuration: quorum = 2,majority
如果 M1 所在机器宕机了,那么三个哨兵还剩下 2 个,S2 和 S3 可以一致认为 master 宕机,然后选举出一个来执行故障转移
同时 3 个哨兵的 majority 是 2,所以还剩下的 2 个哨兵运行着,就可以允许执行故障转移
-中华石杉:亿级流量电商详情页系统实战(第二版):缓存架构+高可用服务架构+微服务架构
-Mrcode笔记本
原文:https://www.cnblogs.com/codecheng99/p/12383570.html