Redis Sentinel高可用实战:主从自动故障转移

一、Sentinel 核心概念

监控:持续检查主从节点是否正常

通知:节点异常时通知管理员或其他程序

自动故障转移:主节点下线时,自动选举新的主节点

配置提供者:客户端通过 Sentinel 获取当前主节点地址

回到顶部

二、环境准备

准备三台服务器(或本地三个端口):

复制代码
主节点:192.168.1.100:6379
从节点:192.168.1.101:6379
从节点:192.168.1.102:6379
Sentinel:三个实例,分别部署在三台服务器

回到顶部

三、主从复制配置

从节点配置(redis.conf):

复制代码
replicaof 192.168.1.100 6379
masterauth yourpassword
replica-read-only yes

启动主从节点后验证:

复制代码
redis-cli info replication
# 输出:role:master / role:slave

回到顶部

四、Sentinel 配置详解

创建 sentinel.conf:

复制代码
port 26379
sentinel monitor mymaster 192.168.1.100 6379 2
sentinel auth-pass mymaster yourpassword
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 180000

配置说明:

• monitor:监控名为 mymaster 的主节点,2 表示需要 2 个 Sentinel 同意才能判定主节点下线

• down-after-milliseconds:30秒无响应则判定下线

• failover-timeout:故障转移超时时间

启动 Sentinel:

复制代码
redis-sentinel /etc/redis/sentinel.conf

回到顶部

五、故障转移测试

模拟主节点宕机:

复制代码
redis-cli shutdown

观察 Sentinel 日志:

复制代码
+sdown master mymaster 192.168.1.100 6379
+odown master mymaster 192.168.1.100 6379 #quorum 2/2
+switch-master mymaster 192.168.1.100 6379 192.168.1.101 6379

回到顶部

六、Spring Boot 整合 Sentinel

application.yml 配置:

复制代码
spring:
  redis:
    sentinel:
      master: mymaster
      nodes:
        - 192.168.1.100:26379
        - 192.168.1.101:26379
        - 192.168.1.102:26379
    password: yourpassword

回到顶部

七、生产环境最佳实践

• 至少部署 3 个 Sentinel 实例(奇数个)

• Sentinel 与 Redis 节点物理隔离部署

• 开启 AOF 持久化:appendonly yes

• 设置强密码:requirepass 和 masterauth

回到顶部

八、总结

Redis Sentinel 提供了开箱即用的高可用方案,核心要点:

• 至少 3 个 Sentinel 实例保证可用性

• 合理配置 down-after 和 failover-timeout

• 客户端必须通过 Sentinel 获取主节点地址

相关推荐
AI人工智能+电脑小能手12 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood13 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven
凯瑟琳.奥古斯特13 小时前
Redis是什么及核心特性
前端·css·redis·缓存
早日退休!!!13 小时前
大模型推理瓶颈七层分析模型
java·服务器·数据库
KmSH8umpK14 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第三篇
redis·分布式·wpf
叶小鸡14 小时前
Java 篇-项目实战-天机学堂(从0到1)-day9
java·开发语言
@#¥&~是乱码鱼啦14 小时前
Spring分层架构:Controller、Service、Mapper数据链路,IOC的真实工作意义
java·spring·架构
xieliyu.14 小时前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表
薪火铺子14 小时前
SpringMVC请求处理流程源码解析(第3篇):视图渲染与异常处理
java·后端·spring