通过 Sidecar 注入将遥测数据发送到 OpenTelemetry Collector

你可以配置 Alauda 版 OpenTelemetry v2,将 OpenTelemetry Collector 作为 sidecar 容器注入到你的应用 pod 中。sidecar Collector 与你的应用运行在同一个 pod 中,使应用能够通过 localhost 向 Collector 发送遥测数据,而无需复杂的网络配置。

前提条件

  • 已安装 Alauda 版 OpenTelemetry v2 Operator。
  • 已安装并部署 Alauda 版 Jaeger v2。
  • 由具有 cluster-admin 角色的集群管理员建立的活跃 ACP CLI (kubectl) 会话。

操作步骤

  1. 通过运行以下命令,将 OpenTelemetry Collector 作为 sidecar 部署:

    kubectl apply -f - <<EOF
    apiVersion: opentelemetry.io/v1beta1
    kind: OpenTelemetryCollector
    metadata:
      name: otel-sidecar
      namespace: observability
    spec:
      mode: sidecar
      image: "<image-registry>/asm/opentelemetry-collector:<image-tag>"
      config:
        receivers:
          otlp:
            protocols:
              grpc:
                endpoint:
              http:
                endpoint:
        processors:
          batch: {}
          memory_limiter:
            check_interval: 1s
            limit_percentage: 80
            spike_limit_percentage: 20
        exporters:
          otlp:
            endpoint: "jaeger-<example>-collector:4317"
            tls:
              insecure: true
        service:
          pipelines:
            traces:
              receivers: [otlp]
              processors: [memory_limiter, batch]
              exporters: [otlp]
    EOF
    1. <image-registry>/asm/opentelemetry-collector:<image-tag> 替换为 sidecar Collector 的实际镜像仓库和标签。
    2. jaeger-<example>-collector 替换为你的 Alauda 版 Jaeger v2 collector 的实际 Service 名称。其格式通常为 <instance-name>-collector
  2. 通过添加注解 sidecar.opentelemetry.io/inject: "true" 并使用已创建的 ServiceAccount,创建一个使用 sidecar 注入的 deployment:

    kubectl apply -f - <<EOF
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-app
      namespace: observability
    spec:
      selector:
        matchLabels:
          app: my-app
      replicas: 1
      template:
        metadata:
          labels:
            app: my-app
          annotations:
            sidecar.opentelemetry.io/inject: "true"
        spec:
          containers:
          - name: app
            image: myapp:latest
            ports:
            - containerPort: 8080
    EOF