Redis哨兵(sentinel)用法解读

 更新时间:2026年04月10日 16:20:59   作者:当归. z Z  
本文介绍了Redis Sentinel的故障转移机制,包括监控主从库状态、消息通知、故障转移过程、配置中心等功能,以及具体配置和操作步骤

巡查监控后台master主机是否故障,如果故障了根据投票数自动将某一个从库转换为新主库,继续对外服务。

作用

  • 主从监控:监控主从redis库运行是否正常
  • 消息通知:哨兵可以将故障转移的结果发送给客户端
  • 故障转移:如果master异常,则会进行主从切换,将其中一个slave作为新master
  • 配置中心:客户端通过连接哨兵来获得当前redis服务的主节点地址

示例

1. 在sentinel.conf文件中,使用如下命令设置要监控的master服务器,quorum表示确认客观下线的最少的哨兵数量

sentinel monitor <master-name> <ip> <redis-port> <quorum>

使用如下命令连接master服务的密码

sentinel auth-pass <master-name> <password>

其他配置

sentinel down-after-milliseconds <master-name> <milliseconds>
指定多少毫秒之后,主节点没有应答哨兵,此时哨兵主观上认为主节点下线

sentinel parallel-syncs <master-name> <nums>:
表示允许并行同步的slave个数,当Master挂了后,哨兵会选出新的Master,此时,剩余的slave会向新的master发起同步数据

sentinel failover-timeout <master-name> <milliseconds>:
故障转移的超时时间,进行故障转移时,如果超过设置的毫秒,表示故障转移失败

sentinel notification-script <master-name> <script-path> :
配置当某一事件发生时所需要执行的脚本

sentinel client-reconfig-script <master-name> <script-path>:
客户端重新配置主节点参数脚本

2. 启动哨兵

查看sentinel.log,哨兵启动成功

3. 将主机shutdown模拟主机故障

此时从机get数据时会失去连接,再次get数据重新发起连接,哨兵会从从机中选取新的master

查看主机的sentinel.log,选取了ip为192.168.229.102的从机作为新的master

4. 重新启动原来的主机,可以看到原主机从master变为slave,新的master并不会改变

  • sdown:主观下线,单个sentinel自己主观上检测到的关于master的状态在发送PING心跳后一定时间内(默认30s)没有收到合法回复
  • odown:客观下线,多个sentinel达成一致意见认为一个master客观上已经宕机 
  • 当主节点被判断客观下线后,各个哨兵节点会进行协商,先选举出一个领导者哨兵,并由该哨兵进行故障迁移
  • 哨兵选取新的master时,优先选取原master的直接slave,如果直接slave不可用,才会去寻找slave的slave 

领导者哨兵选取算法——Raft算法

基本思路是先到先得:即在一轮选举中,哨兵A向B发送成为领导者的申请,如果B没有同意过其他哨兵,则会同意A成为领导者

新master选取机制

1. 选出新的master,在健康的slave中,通过优先级(redis.conf中slave-priority或replica-priority,数字越小优先级越高)、复制偏移量、id三层比较选取新的master

2. 重新认定master,领导者哨兵会对选举出的新master执行slaveof no one;对其他slave发送命令使剩余slave称为新master的slave

3. 原master成为新master的slave,领导者哨兵会让原master降级为slave并恢复正常工作

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • tio-boot jfinal-plugins框架整合redis示例详解

    tio-boot jfinal-plugins框架整合redis示例详解

    这篇文章主要为大家介绍了tio-boot jfinal-plugins框架整合redis示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • java启动jar包将日志打印到文本的简单操作

    java启动jar包将日志打印到文本的简单操作

    这篇文章主要介绍了java启动jar包将日志打印到文本的简单操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • SpringCloud Gateway网关功能介绍与使用

    SpringCloud Gateway网关功能介绍与使用

    SpringCloud Gateway 是 Spring Cloud 的一个全新项目,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。这篇文章主要介绍了SpringCloud Gateway网关作用,需要的朋友可以参考下
    2022-12-12
  • spring自定义一个简单的Starter启动器

    spring自定义一个简单的Starter启动器

    这篇文章主要介绍了spring自定义一个简单的Starter启动器,一个 starter其实就是对一个功能的集成封装,然后对外提供一个依赖,让业务去使用,像我们熟悉的 Redis,mongo,mybatis 等均属于,需要的朋友可以参考下
    2023-07-07
  • springboot中如何使用openfeign进行接口调用

    springboot中如何使用openfeign进行接口调用

    这篇文章主要介绍了springboot中如何使用openfeign进行接口调用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 阿里Druid数据连接池引发的线上异常解决

    阿里Druid数据连接池引发的线上异常解决

    这篇文章主要为大家介绍了一次关于阿里Druid数据连接池引发的线上异常问题的解决方案,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • java仿windows记事本功能完整版

    java仿windows记事本功能完整版

    这篇文章主要为大家详细介绍了java仿windows记事本功能完整版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • 使用Java实现PDF文件安全检测功能

    使用Java实现PDF文件安全检测功能

    在日常开发中,我们经常需要处理用户上传的PDF文件,然而,PDF文件可能包含恶意脚本或危险内容,这些内容可能对系统安全构成威胁,本文将介绍如何使用Java实现一个PDF安全检测工具类来防止恶意内容注入,需要的朋友可以参考下
    2025-08-08
  • 基于Java Agent的premain方式实现方法耗时监控问题

    基于Java Agent的premain方式实现方法耗时监控问题

    javaagent是在JDK5之后提供的新特性,也可以叫java代理,这篇文章主要介绍了基于Java Agent的premain方式实现方法耗时监控问题,需要的朋友可以参考下
    2022-10-10
  • 详细聊聊JDK中的反模式接口常量

    详细聊聊JDK中的反模式接口常量

    这篇文章主要给大家介绍了关于JDK中反模式接口常量的相关资料,文中通过实例代码介绍的非常详细,对大家学习或者使用jdk具有一定的参考学习价值,需要的朋友可以参考下
    2022-01-01

最新评论