k8s中应用容器随redis集群自动重启

背景:

业务系统需要使用redis集群做缓存,但是redis集群不稳定会出现宕机问题,宕机后redis自动重启,但是业务系统不能自动重连redis。

改进方案:

当redis集群故障服务不能使用时,业务系统也要随redis一起重启。在业务系统的容器中添加redis服务探查程序。更好的方式是业务系统支持redis的服务的自动重连

复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
  name: business-app-with-monitor
spec:
  replicas: 3
  template:
    metadata:
      labels:
        app: business-app
    spec:
      initContainers:
      - name: redis-preflight-check
        image: busybox:1.35
        command: 
        - /bin/sh
        - -c
        - |
          # 简化的启动前检查
          echo "执行 Redis 集群启动前检查..."
          for i in 0 1 2; do
            if ! nc -z -w 5 redis-$i.redis-headless 6379; then
              echo "❌ redis-$i 不可用"
              exit 1
            fi
            echo "✅ redis-$i 连接成功"
          done
          echo "所有 Redis 节点就绪"
      
      containers:
      # 主业务容器
      - name: business-app
        image: your-business-app:latest
        ports:
        - containerPort: 8080
        env:
        - name: REDIS_CLUSTER_NODES
          value: "redis-0.redis-headless:6379,redis-1.redis-headless:6379,redis-2.redis-headless:6379"
        livenessProbe:
          exec:
            command:
            - /bin/sh
            - -c
            - |
              # 检查应用是否健康,同时检查 Redis 连接
              if ! curl -f http://localhost:8080/health; then
                exit 1
              fi
              
              # 检查 Redis 集群状态
              if ! echo "CLUSTER INFO" | nc -w 3 redis-0.redis-headless 6379 | grep -q "cluster_state:ok"; then
                echo "Redis 集群异常,触发重启"
                exit 1
              fi
          initialDelaySeconds: 30
          periodSeconds: 15
          timeoutSeconds: 10
          failureThreshold: 2
      
      # Redis 监控 Sidecar
      - name: redis-monitor
        image: busybox:1.35
        command:
        - /bin/sh
        - -c
        - |
          echo "启动 Redis 集群监控..."
          
          while true; do
            echo "$(date): 检查 Redis 集群状态..."
            
            # 检查集群健康状态
            cluster_healthy=false
            for node in redis-0.redis-headless:6379 redis-1.redis-headless:6379 redis-2.redis-headless:6379; do
              host=${node%:*}
              port=${node#*:}
              
              if echo "CLUSTER INFO" | nc -w 5 $host $port 2>/dev/null | grep -q "cluster_state:ok"; then
                cluster_healthy=true
                break
              fi
            done
            
            if [ "$cluster_healthy" = "false" ]; then
              echo "❌ $(date): Redis 集群状态异常,触发业务容器重启"
              # 向业务容器发送 SIGTERM 信号,触发重启
              kill -TERM 1
              sleep 10
            else
              echo "✅ $(date): Redis 集群状态正常"
            fi
            
            sleep 30
          done
        resources:
          requests:
            memory: "32Mi"
            cpu: "10m"
相关推荐
架构师老Y4 小时前
008、容器化部署:Docker与Python应用打包
python·容器·架构
win x6 小时前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
handsomestWei8 小时前
Docker引擎API接入配置
运维·http·docker·容器·api
程序员萌萌10 小时前
Redis的缓存机制和淘汰策略详解
数据库·redis·缓存机制·淘汰策略
键盘鼓手苏苏10 小时前
Kubernetes与GitOps高级实践
云原生·kubernetes·k8
不是书本的小明11 小时前
K8S应用优化方向
网络·容器·kubernetes
andeyeluguo13 小时前
docker总结
运维·docker·容器
SuAluvfy13 小时前
从 0 到 1:在 Windows + Docker 环境下搭建 NextChat 并接入多模型 API(踩坑实录)
docker·容器
九英里路13 小时前
cpp容器——string模拟实现
java·前端·数据结构·c++·算法·容器·字符串
尘世壹俗人14 小时前
知识点8---虚拟化编排工具Kubernetes
容器·kubernetes