当前位置: 首页 > news >正文

Redis(43)Redis哨兵(Sentinel)是什么?

Redis Sentinel(哨兵)是一种用于管理 Redis 实例的高可用性解决方案。它提供了监控、通知和自动故障转移等功能,确保 Redis 服务在发生故障时能够自动恢复,提供高可用性和可靠性。以下是详细介绍 Redis Sentinel 的功能及其代码示例。

Redis Sentinel 的功能

  1. 监控(Monitoring)

    • Sentinel 会持续监控主节点和从节点的运行状态,检查它们是否正常工作。
  2. 通知(Notification)

    • 如果 Sentinel 检测到某个节点发生故障,它会通过 API 向系统管理员或其他应用程序发送通知。
  3. 自动故障转移(Automatic Failover)

    • 如果主节点发生故障,Sentinel 会将其中一个从节点提升为新的主节点,并将其他从节点指向新的主节点。
  4. 配置提供者(Configuration Provider)

    • Sentinel 允许客户端应用程序查询当前 Redis 集群的状态信息,以便客户端能够始终连接到正确的主节点。

Sentinel 配置示例

1. 配置 Redis 实例

配置主从架构的 Redis 实例。

主节点配置(master.conf)

port 6379
bind 127.0.0.1
dir /var/lib/redis
appendonly yes

从节点配置(slave.conf)

port 6380
bind 127.0.0.1
dir /var/lib/redis
appendonly yes
slaveof 127.0.0.1 6379

启动主从节点:

redis-server master.conf
redis-server slave.conf
2. 配置和启动 Sentinel

创建 Sentinel 配置文件(sentinel.conf):

port 26379
dir /tmp
sentinel monitor mymaster 127.0.0.1 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 60000

启动 Sentinel:

redis-sentinel sentinel.conf
3. Java 代码示例:使用 Jedis 连接带有 Sentinel 的 Redis 集群

以下 Java 代码展示了如何使用 Jedis 库连接和操作带有 Sentinel 的 Redis 集群。

import redis.clients.jedis.JedisSentinelPool;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.HostAndPort;import java.util.HashSet;
import java.util.Set;public class RedisSentinelExample {public static void main(String[] args) {// 定义 Sentinel 节点Set<String> sentinels = new HashSet<>();sentinels.add("127.0.0.1:26379");// 创建 JedisSentinelPool 对象JedisSentinelPool pool = new JedisSentinelPool("mymaster", sentinels);try (Jedis jedis = pool.getResource()) {// 操作 Redisjedis.set("key", "value");String value = jedis.get("key");System.out.println("Get key: " + value);} finally {// 关闭连接池pool.close();}}
}

详细解释

  1. 监控

    • Sentinel 持续监控主节点和从节点的运行状态。配置文件中的 sentinel monitor mymaster 127.0.0.1 6379 2 表示 Sentinel 监控的主节点是 127.0.0.1:6379,并且至少需要 2 个 Sentinel 同意主节点失效,才会进行故障转移。
  2. 通知

    • sentinel down-after-milliseconds mymaster 5000 配置了 Sentinel 判断主节点失效的时间阈值(毫秒)。超出这个时间后,Sentinel 会认为主节点失效并发送通知。
  3. 自动故障转移

    • sentinel failover-timeout mymaster 60000 配置了 Sentinel 进行故障转移的超时时间。故障转移过程中,Sentinel 会将其中一个从节点提升为新的主节点,并将其他从节点指向新的主节点。
  4. 配置提供者

    • 客户端应用程序(如 Java 代码中的 JedisSentinelPool)可以通过 Sentinel 获取当前主节点的信息,并确保连接的是正确的主节点。

故障转移的示例

为了测试自动故障转移,您可以强制关闭 Redis 主节点,观察 Sentinel 的行为。

# 停止 Redis 主节点
redis-cli -p 6379 shutdown

此时,Sentinel 会检测到主节点失效,并自动提升从节点为新的主节点,然后重新配置集群。

总结

Redis Sentinel 提供了一种高可用性解决方案,通过监控、通知、自动故障转移和配置提供等功能,确保 Redis 服务的可靠性。通过配置 Sentinel 和使用 Jedis 库,客户端应用程序可以方便地连接和操作带有 Sentinel 的 Redis 集群,从而实现高可用性和自动故障恢复。

http://www.xdnf.cn/news/1455841.html

相关文章:

  • 【OpenHarmony文件管理子系统】文件访问接口解析
  • 【笔记】Software Engineering at Google
  • Java Stream 流式操作举例
  • 深度学习篇---SENet
  • AI安全必修课:模型偏见检测与缓解实战
  • 使用 Sentry 为 PHP 和 Web 移动小程序提供多平台错误监控
  • 温湿度监控的科技之处是能够将样本的运行数据以数字化的方式展现在管理者面前吗?
  • UE5 UAT
  • iSCSI IP-SAN 部署实战
  • SMARTGRAPHQA —— 基于多模态大模型的PDF 转 Markdown方法和基于大模型格式校正方法
  • 滑动窗口题目:水果成篮
  • C 盘清理技巧分享:释放磁盘空间,提升系统性能
  • ArcGIS学习-15 实战-建设用地适宜性评价
  • 适应新环境:Trae编辑器下的IDEA快捷键定制
  • 解密大语言模型推理:Prompt Processing 的内存管理与计算优化
  • C++语言编程规范-常量
  • 既“强悍”又“灵活”,部署在用户身边,将直播延迟压缩至毫秒级
  • Kafka 学习教程:从基础概念到实践操作
  • 分析流程自动优化!Fabarta个人专属智能体「数据分析」新功能介绍
  • 打工人日报#20250904
  • docker中的mysql变更宿主机映射端口
  • 以StarRocks为例讲解MPP架构和列式存储
  • vscode launch.json 中使用 cmake tools 扩展的命令获取可执行文件目标文件名
  • 设计师的私有化远程协作解决方案,是OpenUI与cpolar组合的标配功能
  • 目标检测系列-Yolov5下载及运行
  • 深度学习下的单阶段通用目标检测算法研究综述2.0
  • Java全栈工程师的实战面试:从Vue到Spring Boot的技术旅程
  • PSU电源原理
  • 双指针扫描使用简述
  • 【AI论文】面向大语言模型(LLMs)的具身强化学习全景图:一项调研综述