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"
相关推荐
蝎子莱莱爱打怪12 小时前
GitLab CI/CD + Docker Registry + K8s 部署完整实战指南
后端·docker·kubernetes
蝎子莱莱爱打怪4 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes
崔小汤呀4 天前
Docker部署Nacos
docker·容器
缓解AI焦虑4 天前
Docker + K8s 部署大模型推理服务:资源划分与多实例调度
docker·容器
1candobetter4 天前
Docker Compose Build 与 Up 的区别:什么时候必须重建镜像
docker·容器·eureka
阿里云云原生5 天前
Kubernetes 官方再出公告,强调立即迁移 Ingress NGINX
kubernetes
至此流年莫相忘5 天前
Kubernetes实战篇之配置与存储
云原生·容器·kubernetes
小马爱打代码5 天前
Docker:完全指南从入门到精通
运维·docker·容器
知我Deja_Vu5 天前
redisCommonHelper.generateCode(“GROUP“),Redis 生成码方法
数据库·redis·缓存