redis哨兵架构基础

5次阅读

共计 1103 个字符,预计需要花费 3 分钟才能阅读完成。

1. 哨兵的介绍

sentinel,中文是哨兵。

哨兵是 redis 集群架构中非常重要的一个组件,主要功能如下:

(1)集群监控:负责监控 reidis master 和 slave 进程是否正常工作;

(2)消息通知:如果某个 redis 实例有故障,那么哨兵负责发送消息作为报警通知给管理员;

(3)故障转移:如果 master node 挂掉了,会自动转移到 slave node 上;

(4)配置中心:如果故障转移发生了,通知 client 客户端新的 master 地址;

哨兵本身也是分布式的作为一个哨兵集群去运行,互相协同工作;

(1)故障转移时,判断一个 master node 宕机了,需要大部分的哨兵都同意才行,涉及到了分布式选举的问题;

(2)即使部分哨兵节点挂了,哨兵集群还是能正常工作的,因为如果 一个作为高可用机制重要组成部分的故障转移系统本身是单点的,那就坑爹了;目前采用的是 sentinel 2 版本,sentinel2 相对于 sentinel 1 来说,重写了很多代码,主要是让故障转移的机制和算法变得更加健壮和简单。

2. 哨兵的核心知识

(1)哨兵至少需要 3 个实例,来保证自己的健壮性;

(2)哨兵 +redis 主从的部署架构,是不会保证数据 0 丢失的,只能保证 redis 集群的高可用性;

(3)对于哨兵 +redis 主从这种负责的部署架构,尽量在测试环境和生产环境,都进行充足的测试和演练;

3. 为什么 redis 哨兵集群只有 2 个节点无法正常工作?

哨兵集群必须部署 2 个以上节点,如果哨兵集群仅仅部署了 2 个哨兵实例,quorum=1

M1 R1

S1 S2

Configuration:quorum = 1 (哨兵节点只要 1 个认为宕机就可以进行切换了)

master 宕机,s1 和 s2 中只要有一个哨兵认为宕机就可以进行切换,同时 s1 和 s2 中会选举出一个哨兵来进行故障转移,同时这个时候,需要 majority,也就是大多数哨兵都是运行的,2 个哨兵的 majority 就是 2,2 个哨兵都运行这,就可以允许执行故障转移,但是整个 M1 和 S2 运行的机器宕机了,那么哨兵只有 1 个了,此时就没有 majority 来允许执行故障转移,虽然另外一台机器还有一个 R1,但是故障转移不会执行;

4. 经典的 3 节点哨兵集群

​ M1

​ S1

R2 R3

S2 S3

Configuration:quorum = 2 majoiry

如果 M1 所在机器宕机了,那么 3 个哨兵还剩下 2 个,S2 和 S3 可以一致认为 master 宕机,然后选举一个来执行故障转移;同时 3 个哨兵的 majoiry = 2,所以还剩下 2 个哨兵运行着,就可以进行故障转移。

更多深入剖析,请 weixin 关注 “SpringForAll” 社区

本文由博客一文多发平台 OpenWrite 发布!

正文完
 0