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

相关推荐
ch.ju2 小时前
Java程序设计(第3版)第二章——引用数据类型:String
java
等....2 小时前
Redis使用
数据库·redis·mybatis
一只小bit2 小时前
Redis 初步入门教程:简单介绍和安装配置
数据库·redis·缓存
yaoxin5211232 小时前
376. Java IO API - 使用 Globbing 和自定义 Filter 过滤目录内容
java·开发语言·python
手握风云-2 小时前
JavaEE 初阶第三十一期:JVM,一次Full GC的架构级思考(下)
java·java-ee
Mr YiRan2 小时前
JNI技术之手写JNIEnv与静态缓存与native异常
java·c++
lifallen2 小时前
Flink Agents:Python 执行链路与跨语言 Actor (PyFlink Agent)
java·大数据·人工智能·python·语言模型·flink
常利兵2 小时前
Spring Boot配置diff:解锁配置管理新姿势
java·spring boot·后端
小臭希2 小时前
Git(代码版本控制系统)
java·git·github