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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

03链表+栈+队列(D2_栈)

目录 讲解一&#xff1a;栈 一、基本介绍 二、代码示例 ------------------------------ 讲解二&#xff1a;单调栈 一、基本介绍 二、适用场景 三、情形示例 1. 寻找左边第一个小于它的数 2. 寻找左边第一个小于它的数的下标 3. 寻找右边第一个大于它的数 4. 寻找右…

春晚魔术中的数学知识

蛇年春晚刘谦魔术又和大家普及了一下编程中的冒泡排序法&#xff0c;思考深入一点&#xff0c;它还涉及到群论和组合数学中的一些知识。 游戏规则和操作步骤&#xff0c;任意打乱三种餐具作为初始状态&#xff1a; 1.筷子和左边的东西互换&#xff0c;如果筷子就在左边&#…

OpenCV:开运算

目录 1. 简述 2. 用腐蚀和膨胀实现开运算 2.1 代码示例 2.2 运行结果 3. 开运算接口 3.1 参数详解 3.2 代码示例 3.3 运行结果 4. 开运算应用场景 5. 注意事项 6. 总结 相关阅读 OpenCV&#xff1a;图像的腐蚀与膨胀-CSDN博客 OpenCV&#xff1a;闭运算-CSDN博客 …

基于Springboot的健身房管理系统【附源码】

基于Springboot的健身房管理系统 效果如下&#xff1a; 系统登陆页面 管理员主页面 器材类型管理页面 健身房管理页面 教练管理页面 用户管理页面 个人信息页面 课程管理页面 研究背景 随着健康意识的不断增强和人们生活水平的提高&#xff0c;健身房已经成为了现代城市中不…

扣子平台音频功能:让声音也能“智能”起来。扣子免费系列教程(14)

在数字化时代&#xff0c;音频内容的重要性不言而喻。无论是在线课程、有声读物&#xff0c;还是各种多媒体应用&#xff0c;音频都是传递信息、增强体验的关键元素。扣子平台的音频功能&#xff0c;为开发者和内容创作者提供了一个强大而灵活的工具&#xff0c;让音频的使用和…

初始Python篇(8)—— 异常

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; Python 目录 异常介绍 异常的处理 try-except try-except-else try-except-else-finally 异常的抛出 常见的异常类型 异常介绍 在…

SSM-MyBatis-总结

文章目录 一、Hello MyBatis1.1 流程1.2 总结 二、Crud 的一些注意点三、参数传递3.1 #{ } VS ${ }3.2 单、复参数传递&#xff08;1&#xff09;单参数&#xff08;2&#xff09;多参数 -- Param&#xff08;3&#xff09;总结 四、查询结果返回--结果封装4.1 ResultType 一般…

【算法设计与分析】实验1:字符串匹配问题的算法设计与求解

目录 一、实验目的 二、实验环境 三、实验内容 四、核心代码 五、记录与处理 六、思考与总结 七、完整报告和成果文件提取链接 一、实验目的 给定一个文本&#xff0c;在该文本中查找并定位任意给定字符串。 1、深刻理解并掌握蛮力法的设计思想&#xff1b; 2、提高应用…

10.6.1 文本文件读、写和追加

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 文本文件的读写通常的做法是建立一个与文件关联的filestream&#xff0c;然后使用StreamReader读取或者StreamWriter写入。 为了详…

DevEco Studio 4.1中如何创建OpenHarmony的Native C++ (NAPI)程序

目录 引言 操作步骤 结语 引言 OpenHarmony的开发工具变化很快&#xff0c;有的时候你安装以前的教程进行操作时会发现界面和操作方式都变了&#xff0c;进行不下去了。比如要在OpenHarmony中通过NAPI调用C程序&#xff0c;很多博文&#xff08;如NAPI篇【1】——如何创建含…

达梦拷贝DM_HOME的复制安装

近期一个项目需求&#xff0c;需要在没有安装包的情况下&#xff0c;将达梦数据库安装到虚机上&#xff08;生产机上安装了达梦&#xff09;&#xff0c;故采用直接打包生产机DM_HOME的方式拷贝至虚机&#xff0c;再依次执行达梦的部分指令完成安装。以下为验证的步骤&#xff…

【MySQL】初始MySQL、库与表的操作

目录 基本使用 使用案例 SQL分类 存储引擎 库的操作 字符集和校验规则 查看系统默认字符集和校验规则 查看数据库支持的字符集 查看数据库支持的字符集校验规则 指定编码常见数据库 校验规则对数据库的影响 操纵数据库 库的备份与恢复 表的操作 创建表 查看表 …

AI大模型开发原理篇-2:语言模型雏形之词袋模型

基本概念 词袋模型&#xff08;Bag of Words&#xff0c;简称 BOW&#xff09;是自然语言处理和信息检索等领域中一种简单而常用的文本表示方法&#xff0c;它将文本看作是一组单词的集合&#xff0c;并忽略文本中的语法、词序等信息&#xff0c;仅关注每个词的出现频率。 文本…

“爱”之浅谈(一)

《九重紫》里 陈嘉有了爱情 从粗糙的一介武夫和赌徒&#xff0c;变得温柔细致 万皇后伤于爱情 从温柔的眼里有爱有光的小姑娘&#xff0c;变成狠毒的残害忠良的、意图谋反的、卷动举国风云的操盘手 “爱让怯懦者勇敢&#xff0c;让高傲者低头” “爱是软肋&#xff0c;也是…

图漾相机搭配VisionPro使用简易教程

文章目录 1.下载并安装VisionPro软件2.下载PercipioCameraForVisionPro软件包3.软件部署4.测试流程4.1 遍历VisionPro SDK支持的参数4.2 设置示例4.2.1_cameraSingle.SetTriggerMode4.2.2 _cameraSingle.SetRegistration4.2.3_cameraSingle.SetInt4.2.4 _cameraSingle.GetInt4.…

Versal - 基础3(AXI NoC 专题+仿真+QoS)

目录 1. 简介 2. 示例 2.1 示例说明 2.2 创建项目 2.2.1 平台信息 2.2.2 AXI NoC Automation 2.2.3 创建时钟和复位 2.3 配置 NoC 2.4 配置 AXI Traffic 2.5 配置 Memory Size 2.6 Validate BD 2.7 添加观察信号 2.8 运行仿真 2.9 查看结果 2.9.1 整体波形 2.9…

iperf 测 TCP 和 UDP 网络吞吐量

注&#xff1a;本文为 “iperf 测网络吞吐量” 相关文章合辑。 未整理去重。 使用 iperf3 监测网络吞吐量 Tom 王 2019-12-21 22:23:52 一 iperf3 介绍 (1.1) iperf3 是一个网络带宽测试工具&#xff0c;iperf3 可以擦拭 TCP 和 UDP 带宽质量。iperf3 可以测量最大 TCP 带宽…

ResNeSt: Split-Attention Networks论文学习笔记

这张图展示了一个名为“Split-Attention”的神经网络结构&#xff0c;该结构在一个基数组&#xff08;cardinal group&#xff09;内进行操作。基数组通常指的是在神经网络中处理的一组特征或通道。图中展示了如何通过一系列操作来实现对输入特征的注意力机制。 以下是图中各部…

自动驾驶---苏箐对智驾产品的思考

1 前言 对于更高级别的自动驾驶&#xff0c;很多人都有不同的思考&#xff0c;方案也好&#xff0c;产品也罢。最近在圈内一位知名的自动驾驶专家苏箐发表了他自己对于自动驾驶未来的思考。 苏箐是地平线的副总裁兼首席架构师&#xff0c;同时也是高阶智能驾驶解决方案SuperDri…

【C++】内联函数inline、关键字auto与新式for

内联函数 内联函数背景 我们在使用C语言中我们都学过函数&#xff0c;我们知道函数在调用的过程中需要开辟栈帧。如果我们需要频繁的调用一个函数&#xff0c;假设我们调用10次Add()函数&#xff0c;那我们就需要建立10次栈帧。我们都知道在栈帧中要做很多事情&#xff0c;例如…