Redis学习之哨兵一

news2025/1/31 3:50:42

一、基本概念

        1.主从复制的问题:

                一旦主节点出现故障需要手动的将一个从节点晋升为主节点同时需要修改应用方的主节点地址还需要通过命令其他节点去复制新的主节点。

                主节点的写能力和存储能力受到单机的限制

        2.高可用:

                

        上图为一主二从的redis主从复制模式下的主节点出现故障

        故障转移过程:

                Ⅰ、主节点故障,客户端连接主节点失败造成复制中断

                Ⅱ、重新选出一个新的主节点,然后执行slaveof no one使其成为新的主节点

                Ⅲ、从节点成为新的主节点后更新应用方的主节点信息并重启

                Ⅳ、客户端命令另一个从节点复制新的主节点

                Ⅴ、原来的主节点恢复后去复制新的主节点

        上述这几个过程不符合高可用的思想,因为这个过程需要人介入

        Redis Sentinel的高可用性:当主节点出现故障时,它可以自动完成故障发现和故障转移并可以通知应用方实现真正的高可用

        Redis Sentinel是一个分布式架构,其包含若干个Sentinel节点和Redis数据节点,其中每个Sentinel节点会对数据节点和其余的Sentinel节点进行监控,当发现节点不可达时会对节点做下线标识,如果标识的时主节点,它会和其他Sentinel节点进行协商,当大多数Sentinel节点认为主节点不可达时,它们会选举一个Sentinel节点来自动完成故障转移工作同时也会将这个实时的变化通知给redis的应用方,整个过程不需要人工介入

        

        Redis Sentinel故障转移逻辑:

                Ⅰ、主节点出现故障,从节点和主节点失去连接主从复制失败

                

                Ⅱ、每个Sentinel节点通过定期监控发现主节点出现故障

        

                Ⅲ、多个Sentinel节点对主节点的故障达成一致并选举出其中一个Sentinel节点作为领导者负责故障转移

        

        

                

                Ⅳ、故障转移后整个redis sentinel拓扑图

        

                根据上述架构图可以得知Redis Sentinel具有以下功能:

                        监控:Sentinel节点会定期检测redis数据节点、其余Sentinel节点是否可达

                        通知:Sentinel节点会将故障转移的结果通知给应用方

                        主节点故障转移:实现从节点晋升主节点并维护后续正确的主从关系

                        配置提供者:在上述结构中,客户端在初始化的时候时Sentinel集合,从中获取主节点的信息

                        Sentinel节点集合是由若干个Sentinel节点组成,这样即使个别Sentinel节点不可用,整个Sentinel节点集合都是健壮的,它们是独立的redis节点但不存储数据只支持部分命令。

        3.Redis Sentinel的安装和部署

                

                Ⅰ、部署redis数据节点

                

                Ⅱ、启动主节点        redis-server  redis-6379.conf

                通过 redis-cli  -h  127.0.0.1 -p 6379  ping 来确认redis的数据节点已经启动

                启动两个从节点

                ​​​​​​​        

                redis-server   redis-6380.conf  redis-6381.conf

                Ⅲ、确认主从关系(从节点视角):

                        

               Ⅳ、 部署Sentinel节点

                

                Sentinel的默认端口是26379,sentinel monitor mymaster127.0.0.163792,其中2表示至少需要两个Sentinel节点同意才可以决定主节点下线

                启动Sentinel节点:redis-sentinel  redis-sentinel-26379.conf  或者  redis-server  redis-sentinel-26379.conf   --sentinel

                        ​​​​​​​           

                Ⅴ、最终的拓扑结构图:

        

        4.相关配置参数解释:

                每个Sentinel节点都要通过定期发送ping命令来判断redis数据节点和其他的Sentinel节点是否可达,如果超过down-after-milliseconds配置的时间没有有效的回复则判断节点不可达,该值越大表示条件越宽松反之越严格。

                parallel-syncs是用来限制在一次故障转移后每次向新的主节点发起复制操作的从节点数,如果该参数配置比较大就会有多个从节点向新的主节点发起复制操作,虽然该操作不会引起阻塞,但是也会对主节点所在的机器造成一定的网络等资源的额外开销。

                

                failover-timeout故障转移超时时间,作用于故障转移的各个阶段:

                        Ⅰ、选出合适的从节点

                        Ⅱ、晋升选出的从节点为主节点

                        Ⅲ、命令其余的从节点复制新的主节点

                        Ⅳ、等待原主节点回复后命令它去复制新的主节点

                如果redis sentinel对一个主节点故障转移失败,下次对该主节点做故障转移的起始时间是failover-timeout的2倍

                如果对选出的从节点执行slaveof no one失败时,则故障转移失败

                如果将选出的从节点晋升成主节点后再执行info命令确认选出的节点确实晋升成为主节点,如果这个过程超过failover-timeout则表示故障转移失败

        

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

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

相关文章

【C++高并发服务器WebServer】-9:多线程开发

本文目录 一、线程概述1.1 线程和进程的区别1.2 线程之间共享和非共享资源1.3 NPTL 二、线程操作2.1 pthread_create2.2 pthread_exit2.3 pthread_join2.4 pthread_detach2.5 patch_cancel2.6 pthread_attr 三、实战demo四、线程同步五、死锁六、读写锁七、生产消费者模型 一、…

【时时三省】(C语言基础)文件的随机读写

山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 fseek 根据文件指针的位置和偏移量来定位文件指针 示例: 这个输出的就是ade seek_cur的意思是从当前偏移量 2就是从a往后偏移两个就是d 偏移量 SEEK_CUR…

【python】python基于机器学习与数据分析的二手手机特性关联与分类预测(源码+数据集)【独一无二】

👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。 python基于机器学习与数据分析的二手手机特性关联与…

WPF进阶 | WPF 数据绑定进阶:绑定模式、转换器与验证

WPF进阶 | WPF 数据绑定进阶:绑定模式、转换器与验证 一、前言二、WPF 数据绑定基础回顾2.1 数据绑定的基本概念2.2 数据绑定的基本语法 三、绑定模式3.1 单向绑定(One - Way Binding)3.2 双向绑定(Two - Way Binding)…

【数据结构】动态内存管理函数

动态内存管理 为什么存在动态内存管理动态内存函数的介绍🎊malloc补充:perror函数🎊free🎊calloc🎊realloc 常见动态内存错误对空指针的解引用操作对动态开辟空间的越界访问对非动态开辟内存使用free释放使用free释放一…

neo4j-community-5.26.0 install in window10

在住处电脑重新配置一下neo4j, 1.先至官方下载 Neo4j Desktop Download | Free Graph Database Download Neo4j Deployment Center - Graph Database & Analytics 2.配置java jdk jdk 21 官网下载 Java Downloads | Oracle 中国 path: 4.查看java -version 版本 5.n…

macbook安装go语言

通过brew来安装go语言 使用brew命令时,一般都会通过brew search看看有哪些版本 brew search go执行后,返回了一堆内容,最下方展示 If you meant "go" specifically: It was migrated from homebrew/cask to homebrew/core. Cas…

LCD液晶屏的工作原理以及背光模组

LCD液晶屏的工作原理以及背光模组 液晶屏工作原理 像素点的主要结构背光模组 LCD液晶屏主要由两部分组成,液晶屏和背光模组。背光模组提供均匀稳定的光源,液晶屏控制光线的传播路径,是屏幕显示设定的图像。 液晶屏 LCD的核心是两片玻璃之间…

maven的打包插件如何使用

默认的情况下,当直接执行maven项目的编译命令时,对于结果来说是不打第三方包的,只有一个单独的代码jar,想要打一个包含其他资源的完整包就需要用到maven编译插件,使用时分以下几种情况 第一种:当只是想单纯…

Controller 层优化四步曲

Controller 层优化四步曲 前言 在开发过程中,Controller 层作为系统与外界交互的桥梁,承担着接收请求、解析参数、调用业务逻辑、处理异常等职责。 然而,随着业务复杂度的增加,Controller 层的代码往往会变得臃肿且难以维护。 …

Java后端之AOP

AOP&#xff1a;面向切面编程&#xff0c;本质是面向特定方法编程 引入依赖&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency>示例&#xff1a;记录…

中文输入法方案

使用了三年的自然码双拼&#xff0c;毫无疑问是推荐使用双拼输入法。 三年积累下来的习惯是&#xff1a; 1 自然码方案 2 空格出字 字母选字 直到如今&#xff0c;想要做出改变&#xff0c;是因为这样的方案带来的痛点&#xff1a; 1 使用空格出字就无法使用辅助码&#…

Julius AI 人工智能数据分析工具介绍

Julius AI 是一款由 Casera Labs 开发的人工智能数据分析工具&#xff0c;旨在通过自然语言交互和强大的算法能力&#xff0c;帮助用户快速分析和可视化复杂数据。这款工具特别适合没有数据科学背景的用户&#xff0c;使数据分析变得简单高效。 核心功能 自然语言交互&#x…

机器学习day4

自定义数据集 使用pytorch框架实现逻辑回归并保存模型&#xff0c;然后保存模型后再加载模型进行预测 import numpy as np import torch import torch.nn as nn import torch.optim as optimizer import matplotlib.pyplot as pltclass1_points np.array([[2.1, 1.8],[1.9, 2…

LVGL+FreeRTOS实战项目:智能健康助手(蓝牙模块篇)

HC-05 蓝牙模块简介 功能&#xff1a;支持串口通信的蓝牙模块&#xff0c;广泛应用于无线数据传输。支持 AT 指令配置。 接口&#xff1a;UART 通信&#xff0c;默认波特率为 9600bps。 应用&#xff1a;无线调试、数据传输、无线控制等。 硬件连接 HC-05 引脚功能STM32 连…

【愚公系列】《循序渐进Vue.js 3.x前端开发实践》029-组件的数据注入

标题详情作者简介愚公搬代码头衔华为云特约编辑&#xff0c;华为云云享专家&#xff0c;华为开发者专家&#xff0c;华为产品云测专家&#xff0c;CSDN博客专家&#xff0c;CSDN商业化专家&#xff0c;阿里云专家博主&#xff0c;阿里云签约作者&#xff0c;腾讯云优秀博主&…

Redis学习之哨兵二

一、API 1.sentinel masters:展示被监控的主节点状态及相关的统计信息 2.sentinel master <master name>:展示指定的主节点的状态以及相关的统计信息 3.sentinel slaves <master name>:展示指定主节点的从节点状态以及相关的统计信息 4.sentinel sentinels <mas…

【Linux基础指令】第二期

本期博客的主题依旧是 "基础指令" &#xff1b; 上一期的基础指令链接&#xff1a; 【Linux基础指令】第一期-CSDN博客 &#xff0c;话不多说&#xff0c;正文开始&#xff1a; 一、Linux的指令 1.cp 拷贝功能&#xff1a; cp [stc] [dest] # 将 src文件 拷贝到…

MySQL(表空间)

​开始前先打开此图配合食用 MySQL表空间| ProcessOn免费在线作图,在线流程图,在线思维导图 InnoDB 空间文件中的页面管理 后面也会持续更新&#xff0c;学到新东西会在其中补充。 建议按顺序食用&#xff0c;欢迎批评或者交流&#xff01; 缺什么东西欢迎评论&#xff01;我都…

C26.【C++ Cont】动态内存管理和面向对象的方式实现链表

&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;除夕篇&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8; 目录 1.知识回顾…