Redis学习之哨兵一
一、基本概念
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则表示故障转移失败
相关文章:
Redis学习之哨兵一
一、基本概念 1.主从复制的问题: 一旦主节点出现故障需要手动的将一个从节点晋升为主节点同时需要修改应用方的主节点地址还需要通过命令其他节点去复制新的主节点。 主节点的写能力和存储能力受到单机的限制 2.高可用: 上图为一主二从的redis主从复制模…...
【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)…...
java.util.Random类(详细案例拆解)(已完结)
前言: 小编打算近期更俩三期类的专栏,一些常用的专集类,给大家分好类别总结和详细的代码举例解释。 今天是除夕,小编先祝贺大家除夕快乐啦!! 今天是第六个 java.lang.Math 包中的 java.util.Random类 我…...
【数据结构】动态内存管理函数
动态内存管理 为什么存在动态内存管理动态内存函数的介绍🎊malloc补充:perror函数🎊free🎊calloc🎊realloc 常见动态内存错误对空指针的解引用操作对动态开辟空间的越界访问对非动态开辟内存使用free释放使用free释放一…...
TVM框架学习笔记
TVM是陈天齐等人一个开源的深度学习编译器栈,用于优化和部署机器学习模型到各种硬件后端。它支持多种前端框架,如TensorFlow、PyTorch、ONNX等,并且可以在不同的硬件平台上运行,包括CPU、GPU和专用加速器。官方文档: Apache TVM Documentation — tvm 0.20.dev0 documenta…...
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的核心是两片玻璃之间…...
es数据同步
Logstash 是 Elastic 技术栈中的一个技术,它是一个数据采集引擎,可以从数据库采集数据到 ES 中。可以通过设置 自增 ID 主键 或 更新时间 来控制数据的自动同步: 自增 ID 主键:Logstatsh 会有定时任务,如果发现有主键…...
maven的打包插件如何使用
默认的情况下,当直接执行maven项目的编译命令时,对于结果来说是不打第三方包的,只有一个单独的代码jar,想要打一个包含其他资源的完整包就需要用到maven编译插件,使用时分以下几种情况 第一种:当只是想单纯…...
【Elasticsearch】中数据流需要配置索引模板吗?
是的,数据流需要配置索引模板。在Elasticsearch中,数据流(Data Streams)是一种用于处理时间序列数据的高级结构,它背后由多个隐藏的索引组成,这些索引被称为后备索引(Backing Indices࿰…...
Controller 层优化四步曲
Controller 层优化四步曲 前言 在开发过程中,Controller 层作为系统与外界交互的桥梁,承担着接收请求、解析参数、调用业务逻辑、处理异常等职责。 然而,随着业务复杂度的增加,Controller 层的代码往往会变得臃肿且难以维护。 …...
Java后端之AOP
AOP:面向切面编程,本质是面向特定方法编程 引入依赖: <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency>示例:记录…...
中文输入法方案
使用了三年的自然码双拼,毫无疑问是推荐使用双拼输入法。 三年积累下来的习惯是: 1 自然码方案 2 空格出字 字母选字 直到如今,想要做出改变,是因为这样的方案带来的痛点: 1 使用空格出字就无法使用辅助码&#…...
Elasticsearch中的度量聚合:深度解析与实战应用
在大数据和实时分析日益重要的今天,Elasticsearch以其强大的搜索和聚合能力,成为了众多企业和开发者进行数据分析和处理的首选工具。本文将深入探讨Elasticsearch中的度量聚合(Metric Aggregations),展示其如何在数据分…...
Julius AI 人工智能数据分析工具介绍
Julius AI 是一款由 Casera Labs 开发的人工智能数据分析工具,旨在通过自然语言交互和强大的算法能力,帮助用户快速分析和可视化复杂数据。这款工具特别适合没有数据科学背景的用户,使数据分析变得简单高效。 核心功能 自然语言交互&#x…...
乌兰巴托的夜---音乐里的故事
不知道你有没有听过《乌兰巴托的夜》。 《乌兰巴托的夜Ulaanbaatariin udesh》其实是蒙古国的流行歌曲,1980年代创作,以蒙古国首都乌兰巴托(Ulaanbaatar)的夜晚为背景,表现恋爱中的男女青年爱情的抒情小夜曲ÿ…...
机器学习day4
自定义数据集 使用pytorch框架实现逻辑回归并保存模型,然后保存模型后再加载模型进行预测 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 蓝牙模块简介 功能:支持串口通信的蓝牙模块,广泛应用于无线数据传输。支持 AT 指令配置。 接口:UART 通信,默认波特率为 9600bps。 应用:无线调试、数据传输、无线控制等。 硬件连接 HC-05 引脚功能STM32 连…...
如何部署 Flask 应用程序到生产环境?
在生产环境中部署 Flask 应用程序需要考虑稳定性、安全性、可扩展性和性能。以下是 Flask 应用的常见生产部署方法及最佳实践: 1. 选择部署方式 常见的 Flask 生产环境部署方式包括: 部署方式适用场景说明Gunicorn Nginx适合中小型项目轻量级…...
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》029-组件的数据注入
标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主&…...
Redis学习之哨兵二
一、API 1.sentinel masters:展示被监控的主节点状态及相关的统计信息 2.sentinel master <master name>:展示指定的主节点的状态以及相关的统计信息 3.sentinel slaves <master name>:展示指定主节点的从节点状态以及相关的统计信息 4.sentinel sentinels <mas…...
【Linux基础指令】第二期
本期博客的主题依旧是 "基础指令" ; 上一期的基础指令链接: 【Linux基础指令】第一期-CSDN博客 ,话不多说,正文开始: 一、Linux的指令 1.cp 拷贝功能: cp [stc] [dest] # 将 src文件 拷贝到…...
SpringBoot的细节问题
一、重点填空 Pivotal 团队在原有 spring 框架的基础上开发了全新的Spring Boot框架。Spring Boot框架在开发过程中大量使用 约定优于配置 的思想来摆脱框架中各种复杂的手动配置。Spring Boot 2.1.3版本要求 Java 8 及以上版本的支持。Spring Boot2.1.3版本框架官方声明支持的…...
JavaScript系列(46)-- WebGL图形编程详解
JavaScript WebGL图形编程详解 🎨 今天,让我们深入探讨JavaScript的WebGL图形编程。WebGL是一种基于OpenGL ES的JavaScript API,它允许我们在浏览器中渲染高性能的2D和3D图形。 WebGL基础概念 🌟 💡 小知识ÿ…...
MySQL(表空间)
开始前先打开此图配合食用 MySQL表空间| ProcessOn免费在线作图,在线流程图,在线思维导图 InnoDB 空间文件中的页面管理 后面也会持续更新,学到新东西会在其中补充。 建议按顺序食用,欢迎批评或者交流! 缺什么东西欢迎评论!我都…...
C26.【C++ Cont】动态内存管理和面向对象的方式实现链表
🧨🧨🧨🧨🧨🧨🧨🧨🧨除夕篇🧨🧨🧨🧨🧨🧨🧨🧨🧨 目录 1.知识回顾…...
