如何在 kubernetes yaml 文件的环境变量中分配集群、命名空间和 pod 名称

Sun*_*aha 2 appdynamics kubernetes kubernetes-namespace kubernetes-pod

我需要将集群、命名空间和 pod 名称从我部署在 Kubernetes 集群中的容器传递给 AppDynamics 代理。

我尝试了以下内容,但这不起作用。

containers:
      - env:
        - name: JAVA_OPTS
          value: -Dappdynamics.agent.nodeName=$HOST-$spec.nodeName-spec.PodName
Run Code Online (Sandbox Code Playgroud)

- name: appdynamics.agent.nodeName
  value= $HOST-$spec.nodeName-spec.PodName
Run Code Online (Sandbox Code Playgroud)

任何人都可以在这里帮助我如何收集详细信息并传递给AppD。提前致谢。

mpa*_*bo7 6

你可以得到POD_NAME,并POD_NAMESPACE通过将它们作为环境变量fieldRef

apiVersion: v1
kind: Pod
metadata:
  name: test-env
spec:
  containers:
    - name: test-container
      image: my-test-image:latest
      env:
        - name: MY_NODE_NAME
          valueFrom:
            fieldRef:
              fieldPath: spec.nodeName
        - name: MY_POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        - name: MY_POD_NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: MY_POD_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP
        - name: MY_POD_SERVICE_ACCOUNT
          valueFrom:
            fieldRef:
              fieldPath: spec.serviceAccountName
        - name: REFERENCE_EXAMPLE
          value: "/$(MY_NODE_NAME)/$(MY_POD_NAMESPACE)/$(MY_POD_NAME)/data.log"
  restartPolicy: Never
Run Code Online (Sandbox Code Playgroud)

编辑添加示例 envREFERENCE_EXAMPLE以显示如何引用变量。感谢this answer指出$()插值。

您可以参考此处supports metadata.name, metadata.namespace, metadata.labels, metadata.annotations, spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP的文档中提到的内容。

但是,CLUSTERNAME不是可用的标准属性。根据此PR #22043,如果使用 GCE ,CLUSTERNAME则应将其注入.metadata字段。

否则,您必须CLUSTERNAME.metadata现场手动指定,然后fieldRef将其作为环境变量注入。