为每个要自动检测的 Pod 添加 Pod 模板注释

编辑

要自动检测部署,请更新其 spec.template.metadata.annotations 以包含 co.elastic.apm/attach 键。webhook 会将此键的值与 Helm values 文件中定义的 webhookConfig.agents 值进行匹配。

例如,如果您的 Webhook values 文件包含以下内容

...
webhookConfig:
  agents:
    java:
...

那么您的 co.elastic.apm/attach 值应为 java

apiVersion: apps/v1
kind: Deployment
metadata:
  # ...
spec:
  replicas: 1
  template:
    metadata:
      annotations:
        co.elastic.apm/attach: java 
      labels:
        # ...
    spec:
      #...

APM attacher 配置 webhookConfig.agents.java 匹配 co.elastic.apm/attach: java。如果您定义了其他配置,例如以下 java-dev 配置,并且希望将该定义用于此部署,则此条目应为 java-dev 而不是 java

spec.template.metadata.annotations 值允许您为每个部署设置自定义环境变量和镜像。例如,您的 Helm values 文件可能会配置许多部署:java-dev 可能具有与 java-prod 不同的 APM 环境,而 backend2 使用与其他部署不同的 APM 代理。

agents:
  java-dev:
    image: docker.elastic.co/observability/apm-agent-java:latest
    artifact: "/usr/agent/elastic-apm-agent.jar"
    environment:
      ELASTIC_APM_SERVER_URL: "http://192.168.1.10:8200"
      ELASTIC_APM_ENVIRONMENT: "dev"
      ELASTIC_APM_LOG_LEVEL: "debug"
      ELASTIC_APM_PROFILING_INFERRED_SPANS_ENABLED: "true"
      JAVA_TOOL_OPTIONS: "-javaagent:/elastic/apm/agent/elastic-apm-agent.jar"
  java-prod:
    image: docker.elastic.co/observability/apm-agent-java:1.44.0 
    artifact: "/usr/agent/elastic-apm-agent.jar"
    environment:
      ELASTIC_APM_SERVER_URL: "http://192.168.1.11:8200"
      ELASTIC_APM_ENVIRONMENT: "prod"
      ELASTIC_APM_LOG_LEVEL: "info"
      ELASTIC_APM_PROFILING_INFERRED_SPANS_ENABLED: "true"
      JAVA_TOOL_OPTIONS: "-javaagent:/elastic/apm/agent/elastic-apm-agent.jar"
  backend2:
    image: docker.elastic.co/observability/apm-agent-nodejs:latest
    artifact: "/opt/nodejs/node_modules/elastic-apm-node"
    environment:
      NODE_OPTIONS: "-r /elastic/apm/agent/elastic-apm-node/start"
      ELASTIC_APM_SERVER_URL: "http://192.168.1.11:8200"
      ELASTIC_APM_SERVICE_NAME: "petclinic"
      ELASTIC_APM_LOG_LEVEL: "info"

此处的示例显示了一个 java-prod 配置,该配置指定了代理的特定版本而不是 latest

values.yaml 中定义的唯一 webhookConfig.agents 值是 javanodejs。使用其他值时,必须明确指定 imageartifact*OPTIONS 值。

此处和 webhook 中定义的环境变量优先于 - 覆盖 - Kubernetes 部署中定义的值。例如,如果您的镜像使用 JAVA_TOOL_OPTIONS,则您的镜像设置的值将被忽略,而使用此处或 values.yaml 中设置的值。