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。提前致谢。
你可以得到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将其作为环境变量注入。
| 归档时间: |
|
| 查看次数: |
6847 次 |
| 最近记录: |