目录

  • 基于pub/sub 机制的哨兵集群组成
  • 基于pub/sub 机制的客户端事件通知
  • 由哪个哨兵执行主从切换
  • 哨兵实例是不是越多越好,如果同时调大 down-after-milliseconds 值,对减少误判是不是也有好处

部署多个哨兵实例就形成了一个哨兵集群。哨兵集群中的多个实例共同判断,可以降低对主库下线的误判率。

一旦多个实例组成了哨兵集群,即使有哨兵实例出现故障挂掉了,其他哨兵还能继续协作完成主从库切换的工作,包括判定主库是不是处于下线状态,选择新主库,以及通知从库和客户端。

在配置哨兵的信息时,只需要用到下面的这个配置项设置主库的IP和端口,并没有配置其他哨兵的连接信息。

sentinel monitor <master-name><ip> <redis-port> <quorum>

这些哨兵实例既然都不知道彼此的地址,又是怎么组成集群的呢?

基于pub/sub 机制的哨兵集群组成

哨兵实例之间可以相互发现,要归功于Redis提供的pub/sub机制,即发布/订阅机制。

哨兵只要和主库建立起了连接,就可以在主库上发布消息了,比如说发布它自己的连接信息(IP和端口)。同时也可以从主库上订阅消息,获得其他哨兵发布的连接信息。当多个哨兵实例都在主库上做了发布和订阅操作后,它们之间就能知道彼此的IP地址和端口。

除了哨兵实例,我们自己编写的应用程序也可以通过Redis进行消息的发布和订阅。所以,为了区分不同应用的消息,Redis 会以频道的形式,对这些消息进行分门别类的管理。频道就是消息的类别。当消息类别相同时,它们就属于同一个频道。反之,就属于不同的频道。只有订阅了同一个频道的应用,才能通过发布的消息进行信息交换。

在主从集群中,主库上有一个名为“_ _sentinel_ _:hello”的频道,不同哨兵就是通过它来相互发现,实现互相通信的。

**哨兵除了彼此之间建立起连接形成集群外,还需要和从库建立连接。**这是因为,在哨兵的监控任务中,它需要对主从库都进行心跳判断,而且在主从库切换完成后,它还需要通知从库,让它们和新主库进行同步。

那么,哨兵是如何知道从库的IP地址和端口的呢?

这是由哨兵向主库发送 INFO 命令来完成的。哨兵给主库发送INFO命令,主库接受到这个命令后,就会把从库列表返回给哨兵。哨兵就可以根据从库列表中的连接信息,和每个从库建立连接,并在这个连接上持续地对从库进行监控。

哨兵还需要完成把新主库的信息告诉客户端这个任务。

基于pub/sub 机制的客户端事件通知

从本质上说,哨兵就是一个运行在特定模式下的 Redis 实例,只不过它并不服务请求操作,只是完成监控、选主和通知的任务。所以,每个哨兵实例也提供 pub/sub 机制,客户端可以从哨兵订阅消息。哨兵提供的消息订阅频道有很多,不同频道包含了主从库切换过程中的不同关键事件。

知道了这些频道之后就可以让客户端从哨兵这里订阅消息了。操作步骤是,客户端读取哨兵的配置文件后,可以获得哨兵的地址和端口,和哨兵建立网络连接。然后,我们可以在客户端执行订阅命令,来获取不同的事件消息。

如,可以执行如下命令,来订阅“所有实例进入客观下线状态的事件”:

SUBSCRIBE +odown

也可以执行如下命令,订阅所有的事件:

PSUBSCRIBE *

当哨兵把新主库选择出来后,客户端就会看到下面的switch-master事件。这个事件表示主库已经切换了,新主库的IP地址和端口信息已经有了。这个时候,客户端就可以用这里面的新主库地址和端口进行通信了。

switch-master <master name> <oldip> <oldport> <newip> <newport>

有了这些事件通知,客户端不仅可以在主从切换后得到新主库的连接信息,还可以监控到主从库切换过程中发生的各个重要事件。这样,客户端就可以知道主从切换进行到哪一步了,有助于了解切换进度。

由哪个哨兵执行主从切换

确定由哪个哨兵执行主从切换的过程,和主库“客观下线”的判断过程类似,也是一个“投票仲裁”的过程。

哨兵集群要判定主库“客观下线”,需要有一定数量的实例都认为该主库已经“主观下线”了。

任何一个实例只要自身判断主库“主观下线”后,就会给其他实例发送 is-master-down-by-addr 命令。接着,其他实例会根据自己和主库的连接情况,做出 YN 的响应,Y相当于赞成票,N相当于反对票。

一个哨兵获得了仲裁所需的赞成票数后,就可以标记主库为“客观下线”。这个所需的赞成票数是通过哨兵配置文件中的 quorum 配置项设定的。例如,现在有5个哨兵,quorum 配置的是3,那么,一个哨兵需要3张赞成票,就可以标记主库为“客观下线”了。这3张赞成票包括哨兵自己的一张赞成票和另外两个哨兵的赞成票。

此时,这个哨兵就可以再给其他哨兵发送命令,表明希望由自己来执行主从切换,并让所有其他哨兵进行投票。这个投票过程称为“Leader 选举”。因为最终执行主从切换的哨兵称为Leader,投票过程就是确定Leader。

在投票过程中,任何一个想成为Leader的哨兵,要满足两个条件:第一,拿到半数以上的赞成票;第二,拿到的票数同时还需要大于等于哨兵配置文件中的quorum值。以3个哨兵为例,假设此时的quorum设置为2,那么,任何一个想成为Leader的哨兵只要拿到2张赞成票,就可以了。

如果一轮投票没有产生Leader。哨兵集群会等待一段时间(也就是哨兵故障转移超时时间的2倍),再重新选举。因为哨兵集群能够进行成功投票,很大程度上依赖于选举命令的正常网络传播。如果网络压力较大或有短时堵塞,就可能导致没有一个哨兵能拿到半数以上的赞成票。所以,等到网络拥塞好转之后,再进行投票选举,成功的概率就会增加。

注意:如果哨兵集群只有2个实例,此时,一个哨兵要想成为Leader,必须获得2票,而不是1票。所以,如果有个哨兵挂掉了,那么,此时的集群是无法进行主从库切换的。因此,通常我们至少会配置3个哨兵实例。

**注意:要保证所有哨兵实例的配置是一致的,尤其是主观下线的判断值 down-after-milliseconds。**因为这个值在不同的哨兵实例上配置不一致,会导致哨兵集群一直没有对有故障的主库形成共识,也就没有及时切换主库,最终的结果就是集群服务不稳定。

哨兵实例是不是越多越好,如果同时调大 down-after-milliseconds 值,对减少误判是不是也有好处

哨兵实例越多,误判率会越低,但是在判定主库下线和选举 Leader 时,实例需要拿到的赞成票数也越多,等待所有哨兵投完票的时间可能也会相应增加,主从库切换的时间也会变 长,客户端容易堆积较多的请求操作,可能会导致客户端请求溢出,从而造成请求丢失。 如果业务层对 Redis 的操作有响应时间要求,就可能会因为新主库一直没有选定,新操作无法执行而发生超时报警。

调大 down-after-milliseconds 后,可能会导致这样的情况:主库实际已经发生故障了, 但是哨兵过了很长时间才判断出来,这就会影响到 Redis 对业务的可用性。

Redis:哨兵集群相关推荐

  1. 【带你重拾Redis】Redis 哨兵集群实现高可用

    Redis 哨兵集群实现高可用 哨兵的介绍 sentinel,中文名是哨兵.哨兵是 Redis 集群架构中非常重要的一个组件,主要有以下功能: 集群监控:负责监控 Redis master 和 sla ...

  2. k8s redis集群_基于K8S部署redis哨兵集群

    本 文 主 要 内 容 什么是Kubernetes分布式容器管理平台 PaaS平台redis-sentinel集群架构简介 PaaS平台部署redis哨兵集群 redis-sentinel容器测试及验 ...

  3. redis哨兵集群部署 docker单机模拟-六节点

    目录 如果有不懂得,私信我就行,十分欢迎交流 一.准备工作 二.拉取redis镜像 三.部署多个容器 四.脚本讲解 1.脚本循环 2.配置文件 3.创建docker容器 五.从节点加入主节点 一.加入 ...

  4. Redis哨兵集群搭建

    文章目录 1 为什么要使用哨兵模式 2 哨兵模式的工作原理 3 一主二从三哨兵搭建步骤 4 测试该哨兵集群是否可用 5 Spring Boot连接Redis哨兵集群 1 为什么要使用哨兵模式 主从模式 ...

  5. redis 哨兵集群搭建

    前言 在上一篇,我们了解了redis 复制集群的完整的搭建流程,本篇来分享一下如何搭建 redis 哨兵集群. 为什么需要哨兵集群 redis哨兵集群要解决的问题是什么呢?搞清楚这个问题之后,就知道为 ...

  6. Redis 哨兵集群实现高可用

    哨兵的介绍 sentinel,中文名是哨兵.哨兵是 redis 集群机构中非常重要的一个组件,主要有以下功能: 1,集群监控:负责监控 redis master 和 slave 进程是否正常工作. 2 ...

  7. redis哨兵集群配置

    Redis集群配置(docker环境) 一.redis集群架构图 一主两从三哨兵集群,当master节点宕机时,通过哨兵(sentinel)重新推选出新的master节点,保证集群的可用性. 二.se ...

  8. 详谈redis哨兵集群模式配置

    说到针对大量实时性的数据库存储服务,一般使用redis数据库.redis是一款以key-value形式存储数据的轻量级缓存数据库,在考虑到对数据进行存储的同时,还要考虑到服务器因为异常情况而终止的情况 ...

  9. redis哨兵集群的搭建

    Linux里插入 i 退出并保存 esc :wq  按enter键 搭建哨兵:(主服务器用来插入,从服务器用来做查询) 1.复制conf文件 2.主服务器为:master    从服务器为:slave ...

  10. K8S 部署 redis 哨兵集群

    Redis™ packaged by Bitnami 官方文档 把 bitnami 加入 helm 仓库 helm repo add bitnami https://charts.bitnami.co ...

最新文章

  1. opencv2中访问像素的简单方法-自定义一个宏CV_MAT_ELEM2
  2. python legb_理解 Python 的 LEGB.
  3. 解决 mysql>com.mysql.jdbc.PacketTooBigException: Packet for query is too large (12073681 > 4194304)
  4. 用汇编的眼光看C++(之特殊函数)
  5. 【网络安全工程师面试合集】——网络安全基础知识大总结
  6. 基于route-map的策略路由
  7. 转载 hashtable和dictionary的区别
  8. Compile qt-2.3.10
  9. draw什么计算机软件,[计算机软件及应用]化学绘图软件ChemDraw使用简介.ppt
  10. Python pdf 转jpg/png工具
  11. php下获取客户端IP
  12. postgresql注册表删除_彻底删除SQL Server注册表的方法
  13. 阿里云 mysql 导出数据_mysql数据库导出数据库
  14. 端午趣味征文赛已上线,就等你创作啦
  15. TPTP监控远程Tomcat
  16. 需求工程之原型法获取需求
  17. 计算机操作员试题2018,计算机操作员初级试题及答案(精选).doc
  18. Markdown语法学习|精简版
  19. 店铺信息html,编辑店铺信息.html
  20. 阿里p9教你Java学到什么程度才能叫精通?

热门文章

  1. 分享一颗QC转PD,还支持USB数据传输的协议芯片
  2. qt几种常见安装包制作工具-Qt Installer Framework
  3. 39岁宿华卸任:他们都不当CEO了
  4. 在不学成风的大学里顶风而上
  5. 莫名其妙的电话修改后,变为 2147483647
  6. 三星s9 测试性能软件,三星S9/S9+性能测试:4G内存够用、高分辨率不削弱跑分
  7. Tomcat打破双亲委派机制
  8. Vue项目中链接websocket,做一个全局通知信息
  9. 什么是ajax跨域问题,如何解决ajax跨域问题
  10. WPFDataGrid序列号