Redis学习之哨兵二

一、API

        1.sentinel masters:展示被监控的主节点状态及相关的统计信息

        

                

                

        2.sentinel master <master name>:展示指定的主节点的状态以及相关的统计信息

        3.sentinel slaves <master name>:展示指定主节点的从节点状态以及相关的统计信息

        4.sentinel sentinels <master name>:展示指定主节点的sentinel节点集合

        5.sentinel get-master-addr-by-name<master name>:返回指定主节点的ip地址和端口

        6.sentinel reset<pattern>:对符合pattern的主节点的配置进行重置

        7.sentinel failover<master name>:对指定的主节点进行强制的故障转移,没有和其他sentinel节点进行协商,当故障转移完成后,其他sentinel节点按照故障转移的结果更新自身配置

        8.sentinel flushconfig:将sentinel节点的配置强制刷到磁盘上

        9.sentinel remove<master name>:取消当前sentinel节点对于指定的主节点进行监控

        10.sentinel  monitor <master name><ip><port><quorum>:向sentinel中添加对主节点的监控

        11.sentinel set<master name>:动态修改sentinel节点的配置项

        12.sentinel is-master-down-by-addr:sentinel节点之间用来交换对节点是否下线的判断,还可以根据参数的不同作为sentinel领导者的选举的通信方式

二、客户端连接

        1.实现redis sentinel客户端的步骤:

                Ⅰ、遍历sentinel节点集合获取一个可用的sentinel节点

                Ⅱ、通过sentinel get-master-addr-by-name master-name 获取对应的主节点的信息

                Ⅲ、验证当前获取的主节点是真正的主节点,防止故障转移期间主节点的变化

                Ⅳ、保持和sentinel节点集合的联系,时刻获取关于主节点的相关信息

        2.java操作redis sentinel

                jedis需要有master-name和sentinel两个参数来连接redis sentinel

                

三、redis sentinel实现原理

        1.其基本实现原理包含:三个定时任务、主观下线和客观下线、sentinel领导者选举以及故障转移。

        2.三个定时任务

                Ⅰ、每隔10s,每个sentinel节点会向主节点和从节点发送info命令获取最新的拓扑

                

                这个定时任务的作用表现

                        通过向主节点执行info命令获取从节点的信息,这个好处是sentinel节点不需要显示配置监控从节点

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

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

               Ⅱ、每隔2s,每个sentinel节点会向redis数据节点发送该sentinel节点对于主节点的判断以及当前sentinel节点的信息同时其他sentinel节点也可以得知它们对于主节点的判断

                Ⅲ、每隔1s,每个sentinel节点会向主节点、从节点、其余sentinel节点发送一条ping命令做一次心跳检测来确定这些节点是否可达

        3.主观下线和客观下线

                主观下线:每个sentinel节点会隔1s对其他节点做心跳检测,当这些节点超过down-after-milliseconds没有进行有效的回复,sentinel节点会对该节点做失败判定,这个行为是主观下线,这个行为存在误判的可能。

                客观下线:当sentinel主观下线 的节点是主节点,该sentinel节点会通过sentinel is-master-down-by-addr命令向其他sentinel节点询问对主节点的判断,当超过<quorum>个数就认为主节点有问题,则这个sentinel就会做出客观下线的决定

        4.领导者sentinel节点选举

                领导者sentinel选取的意义:进行故障转移

                领导者选举的思路

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

 

                       Ⅱ、收到命令的sentinel节点如果没有同意其他sentinel节点的命令将会同意这个请求否则是拒绝

                        Ⅲ、如果该sentinel节点发现自己的票数已经大于max(quorum,num(sentinel)/2+1),那么就会成为领导者

                        Ⅳ、如果这个过程没有选举出领导者将会进入下一次选举

         5.故障转移

                在节点列表中选出一个节点作为新的主节点

                       Ⅰ、过滤掉不健康(主观下线)、5s内没有回复ping命令

                        Ⅱ、选择slave-priority(从节点优先级)最高的从节点列表,如果存在则返回

                        Ⅲ、选择复制偏移量最大的从节点,如果存在则返回’

                        Ⅳ、选择runid最小的从节点

                对上一步选出来的从节点执行slaveof no one命令让其成为主节点

                sentinel领导者向剩余的从节点发送命令,让它们成为新主节点的从节点

                sentinel集合将原来的住系欸但更新为从节点并保持对旧的主节点的关注,当旧的主节点恢复时命令它去复制新的主节点的信息。 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/69472.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷U525322 优美区间

优美区间 题目描述 有一个长度为 n n n 的数字序列&#xff0c;序列的第 i i i 个数为 a i a_i ai​。 定义区间 [ l , r ] [l,r] [l,r] 的优美程度为 gcd ⁡ ( a l , a l 1 , … , a r ) ∑ i l r a i \gcd(a_l,a_{l1},\dots,a_r)\times\sum\limits_{il}^ra_i gcd(…

如何把obsidian的md文档导出成图片,并加上文档属性

上篇关于这个插件PKMer_Obsidian 插件&#xff1a;Export Image plugin 一键将笔记转换为图片分享的文章 如何把obsidian的md文档导出成图片&#xff0c;并加上水印-CSDN博客 如何导出图片的时候让文档属性也显示出来&#xff0c;啊啊&#xff0c;这个功能找了一晚上&#xf…

新年祝词(原创)

新年将至&#xff0c;福进万户。 家家团圆&#xff0c;事事顺心。 喜迎财神&#xff0c;多寿添金。 瑞兽迎春&#xff0c;炮竹声起。 趋吉避凶&#xff0c;蛇年大吉。 中华崛起&#xff0c;人人自强。 天下大同&#xff0c;百姓富足。 有情有义&#xff0c;平易近人。 …

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.19 排序革命:argsort的十大高阶用法

1.19 排序革命&#xff1a;argsort的十大高阶用法 目录 #mermaid-svg-Qu8PcmLkIc1pOQJ7 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Qu8PcmLkIc1pOQJ7 .error-icon{fill:#552222;}#mermaid-svg-Qu8PcmLkIc1pOQJ…

TensorFlow实现逻辑回归模型

逻辑回归是一种经典的分类算法&#xff0c;广泛应用于二分类问题。本文将介绍如何使用TensorFlow框架实现逻辑回归模型&#xff0c;并通过动态绘制决策边界和损失曲线来直观地观察模型的训练过程。 数据准备 首先&#xff0c;我们准备两类数据点&#xff0c;分别表示两个不同…

Unity git版本管理

创建仓库的时候添加了Unity的.gitignore模版&#xff0c;在这个时候就能自动过滤不需要的文件 打开git bash之后&#xff0c;步骤git版本管理-CSDN博客 如果报错&#xff0c;尝试重新进git 第一次传会耗时较长&#xff0c;之后的更新就很快了

【AI论文】扩散对抗后训练用于一步视频生成总结

摘要&#xff1a;扩散模型被广泛应用于图像和视频生成&#xff0c;但其迭代生成过程缓慢且资源消耗大。尽管现有的蒸馏方法已显示出在图像领域实现一步生成的潜力&#xff0c;但它们仍存在显著的质量退化问题。在本研究中&#xff0c;我们提出了一种在扩散预训练后针对真实数据…

低代码系统-产品架构案例介绍、明道云(十一)

明道云HAP-超级应用平台(Hyper Application Platform)&#xff0c;其实就是企业级应用平台&#xff0c;跟微搭类似。 通过自设计底层架构&#xff0c;兼容各种平台&#xff0c;使用低代码做到应用搭建、应用运维。 企业级应用平台最大的特点就是隐藏在冰山下的功能很深&#xf…

实时数据处理与模型推理:利用 Spring AI 实现对数据的推理与分析

在现代企业中&#xff0c;实时数据处理与快速决策已经成为关键需求。通过集成 Spring AI&#xff0c;我们不仅可以高效地获取实时数据&#xff0c;还可以将这些数据输入到 AI 模型中进行推理与分析&#xff0c;以便生成实时的业务洞察。 本文将讲解如何通过 Spring AI 实现实时…

制造企业的成本核算

一、生产成本与制造费用的区别 (1)生产成本,是直接用于产品生产,构成产品实体的材料成本。 包括企业在生产经营过程中实际消耗的原材料、辅助材料、备品备件、外购半成品、燃料、动力包装物以及其它直接材料,和直接参加产品生产的工人工资,以及按生产工人的工资总额和规…

2025年AI手机集中上市,三星Galaxy S25系列上市

2025年被认为是AI手机集中爆发的一年&#xff0c;各大厂商都会推出搭载人工智能的智能手机。三星Galaxy S25系列全球上市了。 三星Galaxy S25系列包含S25、S25和S25 Ultra三款机型&#xff0c;起售价为800美元&#xff08;约合人民币5800元&#xff09;。全系搭载骁龙8 Elite芯…

【ESP32】ESP-IDF开发 | WiFi开发 | TCP传输控制协议 + TCP服务器和客户端例程

1. 简介 TCP&#xff08;Transmission Control Protocol&#xff09;&#xff0c;全称传输控制协议。它的特点有以下几点&#xff1a;面向连接&#xff0c;每一个TCP连接只能是点对点的&#xff08;一对一&#xff09;&#xff1b;提供可靠交付服务&#xff1b;提供全双工通信&…

2025数学建模美赛|赛题翻译|E题

2025数学建模美赛&#xff0c;E题赛题翻译 更多美赛内容持续更新中...

【Elasticsearch】Elasticsearch的查询

Elasticsearch的查询 DSL查询基础语句叶子查询全文检索查询matchmulti_match 精确查询termrange 复合查询算分函数查询bool查询 排序分页基础分页深度分页 高亮高亮原理实现高亮 RestClient查询基础查询叶子查询复合查询排序和分页高亮 数据聚合DSL实现聚合Bucket聚合带条件聚合…

什么是循环神经网络?

一、概念 循环神经网络&#xff08;Recurrent Neural Network, RNN&#xff09;是一类用于处理序列数据的神经网络。与传统的前馈神经网络不同&#xff0c;RNN具有循环连接&#xff0c;可以利用序列数据的时间依赖性。正因如此&#xff0c;RNN在自然语言处理、时间序列预测、语…

零售EDI:Costco EDI 项目须知

Costco 是全球领先的会员制仓储式零售商&#xff0c;致力于为会员提供高品质且价格实惠的商品。其经营范围涵盖食品、电子产品、家居用品、服装和办公设备等多个领域。 Costco 的 EDI 对接需求分析 为了更高效地管理其复杂的全球供应链&#xff0c;Costco 采用了先进的 EDI&am…

Kafka运维宝典 (三)- Kafka 最大连接数超出限制问题、连接超时问题、消费者消费时间超过限制问题详细介绍

Kafka运维宝典 &#xff08;三&#xff09; 文章目录 Kafka运维宝典 &#xff08;三&#xff09;一、Kafka Broker 配置中的最大连接数超出限制问题1. 错误原因2. 相关 Kafka 配置参数2.1 connections.max2.2 max.connections.per.ip2.3 num.network.threads2.4 connections.ma…

模板泛化类如何卸载释放内存

CustomWidget::~CustomWidget() {for (size_t i 0; i < buttonManager.registerItem.size(); i) {delete buttonManager.registerItem(exitButton);} } 以上该怎么写删除对象操作&#xff0c;类如下&#xff1a;template <typename T> class GenericManager { public…

在Linux系统上安装.NET

测试系统&#xff1a;openKylin(开放麒麟) 1.确定系统和架构信息&#xff1a; 打开终端&#xff08;Ctrl Alt T&#xff09;&#xff0c;输入cat /etc/os-release查看系统版本相关信息。 输入uname -m查看系统架构。确保你的系统和架构符合.NET 的要求&#xff0c;如果架构…

28. 【.NET 8 实战--孢子记账--从单体到微服务】--简易报表--报表定时器与报表数据修正

这篇文章是《.NET 8 实战–孢子记账–从单体到微服务》系列专栏的《单体应用》专栏的最后一片和开发有关的文章。在这片文章中我们一起来实现一个数据统计的功能&#xff1a;报表数据汇总。这个功能为用户查看月度、年度、季度报表提供数据支持。 一、需求 数据统计方面&…