当前位置: 首页 > news >正文

Redis Sentinel哨兵集群

目录

一、Sentinel实现原理

二、Sentinel集群部署


一、Sentinel实现原理

1、三个定时监控任务

(1).每隔10秒,每个Sentinel节点会向主节点和从节点发送info命令获取最新的拓扑结构,这个定时任务的作用具体可以表现在三个方面:

  • 通过向主节点执行info命令,获取从节点的信息,这也是为什么Sentinel节点不需要显示配置监控从节点

  • 当有新的从节点加入时都可以立刻感知出来

  • 节点不可达或者故障转移后,可以通过info命令实时更新节点拓扑信息

(2).每隔2秒,每个Sentinel节点会向Redis数据节点的sentinel:hello频道上发送该Sentinel节点对于主节点的判断以及当前Sentinel节点的信息,同时每个Sentinel节点也会订阅该频道,来了解其他Sentinel节点以及它们对主节点的判断,所以这个定时任务可以完成以下两个工作:

  • 发现新的Sentinel节点:通过订阅主节点的sentinel:hello了解其他的Sentinel节点信息,如果是新加入的Sentinel节点,将该Sentinel节点信息保存起来,并与该Sentinel节点创建连接。

  • Sentinel节点之间交换主节点的状态,作为后面客观下线以及领导者选举的依据。

(3).每隔1秒,每个Sentinel节点会向主节点、从节点、其余Sentinel节点发送一条ping命令做一次心跳检测,来确认这些节点当前是否可达。

2、主观下线

每个Sentinel节点会每隔1秒对主节点、从节点、其他Sentinel节点发送ping命令做心跳检测,当这个节点超过down-after-milliseconds时间没有进行有效回复,Sentinel节点就会对该节点做失败判定,这个判定行为叫做主观下线

3、客观下线

当Sentinel主观下线的节点是主节点时,该Sentinel节点会通过Sentinel is-master-down-by-addr命令向其他Sentinel节点询问对主节点的判断,当超过半数的Sentinel节点都认为主节点确实有问题,这时该Sentinel节点会做出客观下线的决定,这样客观下线的含义是比较明显了,也就是大部分Sentinel节点都对主节点的下线做了同意的判定,那么这个判定就是客观的。

4、领导者选举

故障转移的工作只需要一个Sentinel节点来完成即可,所以Sentinel节点之间会做一个领导者选举的工作,选出一个Sentinel节点作为领导者进行故障转移的工作。Redis使用了Raft算法实现领导者选举,大致思路如下:

(1).每个在线的Sentinel节点都有资格成为领导者,当他确认主节点主观下线时,会向其他Sentinel节点发送sentinel is-master-down-by-addr命令,要求将自己设置为领导者。

(2).收到命令的节点,如果没有同意过其他节点的请求,则会同意该请求,否则拒绝。

(3).如果某一个节点的票数已经大于等于max(quorum,num(sentinels)/2+1),那么它将成为领导者。

(4).如果此过程没有选举出领导者,将进入下一次选举。

5、故障转移

领导者选举出的Sentinel节点负责故障转移,具体步骤如下:

(1).在从节点列表中选出一个节点作为新的主节点,方法如下:

  • 过滤:"不健康"(主观下线、断线)、5秒内没有回复过Sentinel节点ping响应,与主节点失联超过down-after-milliseconds*10秒。

  • 选择slave-priority(从优先级)最高的从节点列表,如果存在则返回,不存在则继续。

  • 选择复制偏移量最大的从节点

  • 选择runid最小的从节点

(2).领导者节点会对第一步选出来的从节点执行slaveof no one命令,使其成为新主

(3).领导者节点会向剩余的从节点发送命令,让他们成为新主的从节点

(4).Sentinel节点集合会将原来的主节点更新为从节点并保持对其关注,当其恢复后命令它去复制新的主节点。

二、Sentinel集群部署

1.配置一主两从,准备三台主机master、slave1、slave2

2.均下载Redis

yum install -y Redis

3.配置master

(1).配置master的哨兵配置文件

vim/etc/redis/sentinel.conf
  • 打开sentinel monitor mastel哨兵监控

(2)..启动哨兵模式

systemctl start redis-sentinel.service

(3).配置redis配置文件

  • 开启bind绑定

  • 打开主从复制

  • 关闭安全模式

(4).查看监听

netstat -anput | grep redis

4.配置slave1

(1).配置redis.conf文件

vim /etc/redid/redid.conf
  • 打开redis.conf文件的主从配置

(2).配置sentinel.conf文件

vim /etc/redis/sentinel.conf
  • 开启监控模式

(3).重启slave1的redis

systemctl start redis

(4).启动slave1的哨兵模式

systemctl start redis-sentinel.conf

(5).查看监听

netstat -anput | grep redis

5.配置slave2

(1).配置redis.conf文件

vim /etc/redid/redid.conf
  • 打开redis.conf文件的主从配置

(2).配置sentinel.conf文件

vim /etc/redis/sentinel.conf
  • 开启监控模式

(3).重启slave1的redis

systemctl start redis

(4).启动slave1的哨兵模式

systemctl start redis-sentinel.conf

(5).查看监听

netstat -anput | grep redis

6.验证同步是否成功

(1).selve1

(2).selve2

http://www.dtcms.com/a/273848.html

相关文章:

  • 碳中和目标下的全球产业链重构:深度解析与未来路径
  • Maui劝退:用windows直接真机调试iOS,无须和Mac配对
  • 单片机显示Unicode字符介绍
  • PDXP、UDP与HDLC协议技术解析:架构、应用与对比研究
  • SpringBoot 拦截器和过滤器的区别
  • 如何高效验证代理IP的可用性与稳定性
  • 瀚高数据库提交数据后,是否需要COMMIT(APP)
  • oracle
  • 从代码学习深度学习 - 针对序列级和词元级应用微调BERT PyTorch版
  • 线程池拒绝策略执行之后的补偿案例
  • Express + @vladmandic/face-api + mySql 实现人脸识别
  • Oracle 数据库 Dblink
  • 【项目经理】实施项目技术问题
  • 5G标准学习笔记14 - CSI--RS概述
  • Telnet远程连接实验(Cisco)
  • 包稳定的Docker 安装方式(CentOS)
  • 前端实现 MD5 加密
  • 【Linux应用】Ubuntu20.04 aarch64开发板一键安装ROS2(清华源)
  • 登录超时问题的排查方法与预防经验分享
  • 【机器学习】机器学习基础
  • 设计模式笔记_结构型_代理模式
  • GPT3/chatGPT/T5/PaLM/LLaMA/GLM主流大语言模型的原理和差异
  • 触觉反馈手套技术是迈向远程机器人系统灵巧操作的关键一步
  • 【Linux】系统引导修复
  • 【八股消消乐】浅尝Kafka性能优化
  • 服务器机柜与网络机柜各自的优势
  • 微信小程序111~120
  • 十二、k8s工程化管理Helm
  • Docker部署私有仓库
  • Linux_3:进程间通信