【Redis 开发】Redis哨兵

哨兵

  • 作用和原理
    • 服务状态监控
    • 选举新的master
  • 搭建哨兵集群
  • RedisTemplate的哨兵模式

作用和原理

Redis提供了哨兵机制来实现主从集群中的自动故障恢复:
在这里插入图片描述
哨兵也是一个集群

  1. 监控:会不断检查master和slave是否按预期工作
  2. 自动故障恢复:如果master故障,Sentinel会将一个slave提升为master,当故障实例恢复也以新的master为主
  3. 通知:哨兵充当Redis客户端的服务发现来源,当集群发生故障转移时,会将新信息推送给Redis客户端

服务状态监控

哨兵基于心跳机制监测服务状态,每个1秒向集群的每个实例发送ping命令:
主观下线:如果某哨兵节点发现某实例未在规定时间内响应,则认为该实例主观下线
客观下线:若超过指定数量的哨兵都认为该实例主观下线,则该实例客观下线,这个值最好超过哨兵实例数量的一半

选举新的master

当master故障,哨兵需要在salve中选择一个作为新的master,依据:

  1. 判断salve节点与master节点断开时间长短,如果超过指定值(down-after-milliseconds*10)则会排除slave节点
  2. 然后判断slave节点的slave-priority值,越小优先级越高,如果是0则永不参与选举
  3. 如果slave-priority一样,则判断slave节点的offset值,越大说明数据较新,优先级越高
  4. 最后判断slave节点的运行id大小,越小优先级越高
  • 选择完成之后如何让从节点变为主节点
  1. 哨兵给备选的slave节点发送slaveof no one命令,让该节点成为master
  2. 哨兵给所有其他的slave节点发送slaveof 192.168.75.135 7002命令,让这些slave成为新master的从节点,开始从新的master上同步数据
  3. 最后,哨兵将故障节点标记为slave,当故障节点恢复后会自动成为新的master的slave节点
    在这里插入图片描述

搭建哨兵集群

这里我们讲述在Linux下搭建三个三个哨兵

  1. /tmp下创建三个目录,mkdir s1 s2 s3
  2. 在s1目录下创建一个sentinel.conf文件,添加内容
port 27001  #配置端口
sentinel announce-ip 192.168.150.101   # 声明自己的ip实例
sentinel monitor mymaster 192.168.150.101 7001 2  # 监控master,时间监控整个集群,2标识之前主观下线的值
sentinel down-after-milliseconds mymaster 5000  #与master连接的超时时间
sentinel failover-timeout mymaster 60000  #与故障恢复的超时时间
dir "/tmp/s1"  #工作目录,实例的存放位置
  1. 将该配置文件拷贝到s2,s3目录中
    echo s2 s3 | xargs -t -n 1 cp s1/sentinel.conf
  2. 修改两个目录下的配置文件将端口分别修改为27002,27003
    sed -i -e 's/27001/27002/g' -e 's/s1/s2/g' s2/sentinel.conf,其他目录相同命令
  3. 启动,打开三个窗口执行redis-sentinel s1/sentinel.conf,剩下两个也同样

RedisTemplate的哨兵模式

在Sentinel集群监管下的Redis主从集群,其节点会因为自动故障转移而发生变化,Redis的客户端必须感知这种变化,及时更新连接信息。Spring的RedisTemplate底层利用lettuce实现了节点的感知和自动切换。

  1. 引入redis的start的依赖
  2. 在配置文件中设置哨兵信息
spring:redis:sentinel:master: hhh #指定master名称nodes: #指定哨兵集群信息-192.168.75.135:27001-192.168.75.135:27002-192.168.75.135:27003
  1. 在配置类中配置Redis集群的读写分离
@Bean
public LettceClientConfigurationBuilderCustomizer configurationBuilderCustomizer(){return configBuilder->configBuilder.readFrom(ReadFrom.REPLICA_PREFERRED);
}

这里的ReadFrom是配置Redis的读取操作,是一个枚举:

标识意义
MASTER从主节点读取
MASTER_PREFERRED优先从master节点读取,master不可用才读取replica
REPLICA从slave(replica)节点读取
REPLICA_PREFERRED优先从slave节点读取,所有的节点都不可用才读取master

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

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

相关文章

本地生活服务平台有哪些?哪个靠谱?

随着多家互联网大厂的本地生活服务布局日益展开,不少人都看到了其中的巨大市场缺口和广阔前景,想要入驻本地生活服务平台,瓜分这块巨大的蛋糕。而在当下这个选择大于努力的时代,能否分到蛋糕以及分到多少蛋糕的关键,就…

Vast+产品展厅 | Vastbase G100数据库是什么架构?(2)

Vastbase G100是海量数据融合了多年对各行业应用场景的深入理解,基于openGauss内核开发的企业级关系型数据库。 上一期,《Vast产品展厅》为您介绍了Vastbase G100的部署架构和物理架构。 本期,我们将为您详细讲解Vastbase G100的物理架构和…

基于Python实现心脏病数据可视化DEA+预测【500010103.1】

一、数据说明 该心脏病数据集是通过组合 5 个已经独立可用但以前未合并的流行心脏病数据集来策划的。在这个数据集中,5 个心脏数据集结合了 11 个共同特征,使其成为迄今为止可用于研究目的的最大心脏病数据集。 该数据集由 1190 个实例和 11 个特征组成…

PVE虚拟机隐藏状态栏虚拟设备

虚拟机启动后,状态栏会出现一些虚拟设备,点击弹出会导致虚拟机无法使用。 解决方案: 1、在桌面新建disable_virtio_removale.bat文件,内容如下: ECHO OFF FOR /f %%A IN (reg query "HKLM\SYSTEM\CurrentContro…

低代码+定制物资管理:创新解决方案探析

引言 在当今快速变化的商业环境中,企业面临着不断增长的挑战,如提高效率、降低成本、满足客户需求等。为了应对这些挑战,企业需要不断创新并采用先进的技术解决方案。在这样的背景下,低代码开发和定制化物资管理成为了引领企业变…

Spark-机器学习(7)分类学习之决策树

在之前的文章中,我们学习了分类学习之支持向量机,并带来简单案例,学习用法。想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢。…

selenium在Pycharm中结合python的基本使用、交互、无界面访问

下载 下载与浏览器匹配的浏览器驱动文件,这里一定注意的是,要选择和浏览器版本号相同的驱动程序,否则后面会有很多问题。 (1)浏览器(以google为例)版本号的查询: 我这里的版本号是1…

MySQL数据库安装——zip压缩包形式

安装压缩包zip形式的 MySQL 8数据库 一 、先进入官网下载 https://dev.mysql.com/downloads/mysql/ 二、解压到某个文件夹 我解压到了D:\mysql\mysql8 下面 然后在这个文件夹下手动创建 my.ini 文件和 data 文件夹 my.ini 内容如下: 注意 basedir 和 datadi…

vue做导入导出excel文档

系统中经常会遇到要实现批量导入/导出数据的功能,导入就需要先下载一个模板,然后在模板文件中填写内容,最后导入模板,导出就可能是下载一个excel文件。 1、导出 新建一个export.js文件如下: import {MessageBox,Mes…

文件摆渡:安全、高效的摆渡系统助力提升效率

很多组织和企业都会通过网络隔离的方式来保护内部的数据,网络隔离可以是物理隔离,也可以是逻辑隔离,如使用防火墙、VPN、DMZ等技术手段来实现,隔离之后还会去寻找文件摆渡方式,来保障日常的业务和经营需求。 进行网络隔…

线上社交app的搭建,圈子社交系统,小程序+app+H5三端,源码交付,支持二开!

在科技飞速发展的大背景下,年轻人社交不再局限于面对面,线上社交app已深入各大年轻人的手机中。相比于传统交友方式,线上社交app为用户提供了更加新奇的交友体验。同时,它还可以吸引更多的朋友,提高用户的整体交友体验…

Spring Boot整合Redisson的两种方式

项目场景 Spring Boot整合Redisson的两种方式,方式一直接使用yml配置,方式二创建RedissonConfig配置类。 前言 redisson和redis区别: Redis是一个开源的内存数据库,支持多种数据类型,如字符串、哈希、列表、集合和有序…

python-pytorch 如何使用python库Netron查看模型结构(以pytorch官网模型为例)0.9.2

Netron查看模型结构 参照模型安装Netron写netron代码运行查看结果需要关注的地方 2024年4月27日14:32:30----0.9.2 参照模型 以pytorch官网的tutorial为观察对象,链接是https://pytorch.org/tutorials/intermediate/char_rnn_classification_tutorial.html 模型代…

数码摄影色彩构成,数码相机色彩管理

一、资料描述 本套摄影色彩资料,大小58.54M,共有6个文件。 二、资料目录 《抽象彩色摄影集》.阿瑟.pdf 《色彩构成》.pdf 《色彩学》.星云.扫描版.pdf 《摄影色彩构成》.pdf 《数码相机色彩管理》.pdf 数码摄影进阶之4《色彩篇》.pdf 三、资料下…

Qt 把.exe打包成安装文件形式

目录 1.下载工具 Qt Installer Framework2.将bin文件添加到环境变量3.拷贝startmenu示例-备用4.准备Qt Release打包好的程序5.把Release打包好的程序放到packages\org.qtproject.ifw.example\data文件夹下6.生成安装包7.修改安装包图标8.修改主程序程序安装引导-创建快捷键9.添…

FFmpeg下载教程(Windows版)

文章目录 下载地址步骤 下载地址 https://ffmpeg.org/download.html 步骤

win c++使用lua环境配置 5.3.5版本

编译lua 下载lua源码,github仓库 使用vs编译源码,新建一个静态库项目(只会生成lib文件),想要dll的话就新建dll项目(有一个lib文件和dll文件) 把lua源码下面的文件夹都是,复制到vs项目中 lib目录是我手动…

iOS - 多线程-读写安全

文章目录 iOS - 多线程-读写安全1. 多读单写1.1 场景1.2 实现方案1.2.1 pthread_rwlock:读写锁1.2.1.1 示例 1.2.2 dispatch_barrier_async:异步栅栏调用1.2.2.1 示例 iOS - 多线程-读写安全 假设有一个文件,A线程进行读取操作,B…

牛客社区帖子分页显示实现

下图是前端分页的组件: 下面是对应的静态html页面,每一个方块,都是一个a标签,可以点击,执行的链接是/community/index,GET请求,拼接的参数是current,也就是pageNum,只需…

ACE框架学习3

ACE Acceptor-Connector框架 该框架实现 Acceptor-Connector 模式,该模式解除了“网络化应用中的协作对端服务的连接和初始化”与“连接和初始化之后它们所执行的处理”的耦合。Acceptor-Connector 框架允许成用独立于它们所提供的服务来配置其连接布局的关键属性。…