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 获取主节点地址

相关推荐
nanxun8862 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103515 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师6 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师10 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_010 小时前
mac(m5)平台编译openjdk
java
用户3169353811831 天前
Java连接Redis
redis
唐青枫1 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java