Agent-skills observability-edot-dotnet-instrument

install
source · Clone the upstream repo
git clone https://github.com/elastic/agent-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/elastic/agent-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/observability/edot-dotnet-instrument" ~/.claude/skills/elastic-agent-skills-observability-edot-dotnet-instrument && rm -rf "$T"
manifest: skills/observability/edot-dotnet-instrument/SKILL.md
source content

EDOT .NET Instrumentation

Read the setup guide before making changes:

Guidelines

  1. Add NuGet packages:
    Elastic.OpenTelemetry
    and
    OpenTelemetry.Instrumentation.AspNetCore
    (for ASP.NET Core apps)
  2. Register EDOT in startup: call
    builder.AddElasticOpenTelemetry()
    on the
    IHostApplicationBuilder
    (in
    Program.cs
    or equivalent). Without this, no telemetry is collected
  3. Set exactly three required environment variables:
    • OTEL_SERVICE_NAME
    • OTEL_EXPORTER_OTLP_ENDPOINT
      — must be the managed OTLP endpoint or EDOT Collector URL. Never use an APM Server URL (no
      apm-server
      , no
      :8200
      , no
      /intake/v2/events
      )
    • OTEL_EXPORTER_OTLP_HEADERS
      "Authorization=ApiKey <key>"
      or
      "Authorization=Bearer <token>"
  4. Do NOT set
    OTEL_TRACES_EXPORTER
    ,
    OTEL_METRICS_EXPORTER
    , or
    OTEL_LOGS_EXPORTER
    — the defaults are already correct
  5. Do NOT manually configure
    TracerProvider
    or
    MeterProvider
    AddElasticOpenTelemetry()
    handles everything
  6. Never run both classic Elastic APM agent (
    Elastic.Apm.*
    ) and EDOT on the same application

Examples

See the EDOT .NET setup guide for complete examples.