部署模板中的 Kubernetes 探针

问题描述

我有一个关于 Kubernetes Liveness/Readiness 探针配置的问题。

我有一个netCore 3.1 中开发的应用程序,目前在生产环境(1.0.0 版)中没有配置运行状况检查。 我已经在第二个版本(2.0.0 版)中实现了 health 端点,但如何管理 Kubernetes 部署模板文件以符合没有端点的 v1 版本? >

如果我在配置探针的情况下部署我的模板,则所有在 v1 上运行的容器都将失败,导致无法访问任何端点。 我想了解是否可以维护一个与 v1(无健康)和 v2(有健康)兼容的部署 yml 文件

这里我发布了一个我实际部署 yml 的例子:

apiVersion: apps/v1
kind: Deployment
Metadata:
  namespace: "#{tenant}#-test-app"
  name: "#{tenant}#-test-app"
  labels:
    app: "#{tenant}#-test-app"
    product: "#{tenant}#-test-app"
    app.kubernetes.io/name: "#{tenant}#-test-app"
    app.kubernetes.io/version: "#{server_image_version}#"
    app.kubernetes.io/component: "test-app"
    app.kubernetes.io/part-of: "#{tenant}#-test-app"
    app.kubernetes.io/managed-by: "#{managed_by}#"
spec:
  selector:
    matchLabels:
      app: "#{tenant}#-test-app"
  template:
    Metadata:
      labels:
        app: "#{tenant}#-test-app"
    spec:
      containers:
        - name: "#{tenant}#-test-app"
          image: mycontainerregistryurl/test-app:#{server_image_version}#
          ports:
            - containerPort: 80
          envFrom:
            - configMapRef:
                name: "#{tenant}#-test-app-variables-config"
          env:
            - name: DD_AGENT_HOST
              valueFrom:
                fieldRef:
                  fieldpath: status.hostIP
            - name: DD_SERVICE_NAME
              value: "#{tenant}#-test-app"
          securityContext:
            allowPrivilegeEscalation: false
            capabilities:
              drop:
                - NET_RAW
      imagePullSecrets:
        - name: test-registries

server_image_version 变量可用于确定我是否必须执行健康检查。

提前致谢,戴夫。

解决方法

要检查 k8s 的活跃度,您可以使用这样的命令,我们可以定义一个环境变量,然后在活跃度部分我们可以使用 cammand 来创建 if-else 来检查当前版本并指定我们需要在每个部分执行。

env:
- name: version
  value: v2
livenessProbe:
  exec:
    command:
    - /bin/bash
    - -exc
    - |
          set +x
          echo "running below scripts"
          if [[ $version -eq "v1" ]]; then
            echo "Running script or command for version 1 "
          else
            echo "Running wget to check the http healthy "
              wget api/v2
          fi

希望我的想法可以帮助您解决问题。