首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Redis Sentinel 及 Redisson 连接问题全解析

Redis Sentinel 及 Redisson 连接问题全解析

原创
作者头像
xcbeyond
发布2025-11-21 21:56:39
发布2025-11-21 21:56:39
710
举报
文章被收录于专栏:系统运维系统运维

在 Kubernetes (k8s) 环境下使用 Redis Sentinel 进行高可用部署时,可能会遇到 failover 超时Sentinel 误判Spring Boot 连接失败 以及 Redisson 配置错误等问题。本文将对这些问题进行汇总分析,并提供详细的解决方案。


1️⃣ Redis Sentinel 介绍

Redis Sentinel 是 Redis 的高可用组件,主要功能包括:

  • 主节点故障检测:判断 Redis 主节点是否宕机。
  • 自动故障转移:当主节点不可用时,选举新的主节点。
  • 通知客户端:应用程序(如 Spring Boot、Redisson)可以通过 Sentinel 获取最新的主节点地址。

Redis Sentinel 关键配置(sentinel.conf):

代码语言:javascript
复制
sentinel monitor mymaster redis-master 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
sentinel parallel-syncs mymaster 1
  • down-after-milliseconds mymaster 5000:如果 5 秒内主节点无响应,认为其不可用。
  • failover-timeout mymaster 60000:Sentinel 允许 60 秒内完成故障转移。

2️⃣ Redis Sentinel 报错分析

🚨 问题 1:Redis 日志报 failover-timeout

🔍 可能原因
  • 副本同步未完成,Sentinel 不能立即选出新的主节点。
  • 网络抖动,导致 Sentinel 误判主节点宕机。
  • Sentinel 数量不足,无法进行有效投票。
✅ 解决方案

1️⃣ 检查 Redis 副本同步状态

代码语言:javascript
复制
kubectl exec -it redis-master-0 -- redis-cli INFO replication

如果 connected_slaves: 0,说明没有可用副本,Sentinel 可能无法完成切换。

2️⃣ 增大 failover-timeout

代码语言:javascript
复制
sentinel failover-timeout mymaster 120000  # 增加至 120 秒

然后重启 Sentinel:

代码语言:javascript
复制
kubectl delete pod -l app=redis-sentinel

3️⃣ 检查 Sentinel 是否足够

代码语言:javascript
复制
kubectl get pods -l app=redis-sentinel

如果 num-other-sentinels: 0,需要增加副本:

代码语言:javascript
复制
spec:
  replicas: 3  # 至少 3 个 Sentinel

🚨 问题 2:Spring Boot 连接 Redis Sentinel 一直报 added 和 is down

🔍 可能原因
  • spring.redis.sentinel.master 配置错误,导致 Spring Boot 连接不上 Redis Sentinel。
  • sentinel.conf 里 mymaster 拼写错误,导致 Sentinel 无法正确发现主节点。
✅ 解决方案

1️⃣ 检查 sentinel.conf 配置

代码语言:javascript
复制
kubectl exec -it redis-sentinel-0 -- redis-cli -p 26379 SENTINEL MASTER mymaster

如果 mymaster 不存在,说明 Sentinel 配置错误。

2️⃣ 检查 Spring Boot 配置

代码语言:javascript
复制
spring:
  redis:
    sentinel:
      master:mymaster# 必须和 Sentinel 配置一致
      nodes:
        -redis-sentinel-0:26379
        -redis-sentinel-1:26379
        -redis-sentinel-2:26379
    password:yourpassword

3️⃣ 调整 timeout 以减少误判

代码语言:javascript
复制
spring:
  redis:
    timeout: 5000
    lettuce:
      pool:
        max-active: 10
        max-wait: 5000

3️⃣ Redisson 连接 Redis Sentinel 配置

Redisson 是一个高效的 Redis 客户端,支持 Redis Sentinel 模式。

🚀 依赖

在 pom.xml 中引入:

代码语言:javascript
复制
<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson-spring-boot-starter</artifactId>
    <version>3.23.2</version>
</dependency>

🚀 配置 RedissonClient

代码语言:javascript
复制
import org.redisson.Redisson;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
publicclass RedissonConfig {
    @Bean
    public RedissonClient redissonClient() {
        Config config = new Config();
        config.useSentinelServers()
              .setMasterName("mymaster")
              .addSentinelAddress("redis://redis-sentinel-0:26379",
                                  "redis://redis-sentinel-1:26379",
                                  "redis://redis-sentinel-2:26379")
              .setPassword("yourpassword")
              .setTimeout(5000)
              .setConnectTimeout(10000);
        return Redisson.create(config);
    }
}

4️⃣ 测试 Redisson 连接

代码语言:javascript
复制
import org.redisson.api.RBucket;
import org.redisson.api.RedissonClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
publicclass RedisController {
    privatefinal RedissonClient redissonClient;

    public RedisController(RedissonClient redissonClient) {
        this.redissonClient = redissonClient;
    }

    @GetMapping("/set")
    public String set(@RequestParam String key, @RequestParam String value) {
        RBucket<String> bucket = redissonClient.getBucket(key);
        bucket.set(value);
        return"Set " + key + " = " + value;
    }

    @GetMapping("/get")
    public String get(@RequestParam String key) {
        RBucket<String> bucket = redissonClient.getBucket(key);
        return"Get " + key + " = " + bucket.get();
    }
}

5️⃣ 可能的错误 & 解决方案

❌ Unable to connect to Redis Sentinel

✅ 解决方案

  • 检查 Sentinel 是否正常运行 kubectl get pods -l app=redis-sentinel 如果 Sentinel Pod 挂了,需要重新启动。
  • 手动测试 Sentinel redis-cli -p 26379 SENTINEL MASTER mymaster 如果 mymaster 不存在,说明 Sentinel 配置有误。

🔎 总结

🚀 Redis Sentinel + Redisson 高可用方案的关键要点:1️⃣ Redis Sentinel 需配置正确mymaster 名称需一致,failover-timeout 需足够长。 2️⃣ Spring Boot 连接 Redis Sentinel 时spring.redis.sentinel.master 需要匹配 Sentinel 配置。 3️⃣ Redisson 连接 Sentinel 需要手动配置 RedissonClient,并保证 sentinel.conf 正确。 4️⃣ 故障排查时,手动执行 SENTINEL MASTER mymaster,检查主节点状态。

📢 如果你仍然遇到问题,可以提供 redis-cli 的 SENTINEL MASTER mymaster 输出,我可以帮你分析!🚀

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1️⃣ Redis Sentinel 介绍
  • 2️⃣ Redis Sentinel 报错分析
    • 🚨 问题 1:Redis 日志报 failover-timeout
      • 🔍 可能原因
      • ✅ 解决方案
    • 🚨 问题 2:Spring Boot 连接 Redis Sentinel 一直报 added 和 is down
      • 🔍 可能原因
      • ✅ 解决方案
  • 3️⃣ Redisson 连接 Redis Sentinel 配置
    • 🚀 依赖
    • 🚀 配置 RedissonClient
  • 4️⃣ 测试 Redisson 连接
  • 5️⃣ 可能的错误 & 解决方案
    • ❌ Unable to connect to Redis Sentinel
  • 🔎 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档