The State of Profiling

A little over six months ago, OpenTelemetry announced support for the profiling signal. While the signal is still in development and isn’t yet recommended for production use, the Profiling SIG has made substantial progress on many fronts.

This post provides a summary of the progress the Profiling SIG has made over the past six months.

OTLP improvements

Profiles were added as a new signal type to OTLP in v1.3.0, though this area is still marked as unstable as we continue to make changes to it.

While our original intent was to keep wire compatibility with pprof, that goal proved impractical, so the Profiling SIG has decided to refactor the protocol and not aim for strict compatibility with pprof. Instead, we will aim for convertibility, similarly to what we already do for other signals. This shift is still a work in progress, and is causing several breaking changes to the profiling section of the protocol. Note that this has no impact on the stable sections that make up the majority of the OTLP protocol, like metrics, spans, logs, resources, etc.

eBPF agent improvements

Back in June, the donation of the Elastic Continuous Profiling Agent was finalized. Since then, the opentelemetry-ebpf-profiler repository has been buzzing with improvements.

Our next goal for the eBPF agent is for it to run as a Collector receiver. Once this is complete, the Collector can be run on every node as an agent, which collects profiles for that host and forwards them using OTLP. This architecture will allow us to extract some specific parts of the agent that aren’t strictly profiling, such as retrieving host metadata and system metrics, and move them to processors, making the agent lighter and more modular.

Collector support

Since v0.112.0, the OpenTelemetry Collector is able to receive, process and export profiling data, and has support for profile ingestion and export using OTLP.

You can try it out by enabling the service.profilesSupport feature gate in your collector, followed by a configuration similar to the following, which ingests and exports data using OTLP:

receivers:
  otlp:
    protocols:
      grpc:
exporters:
  otlp:
    endpoint: 'localhost:4317'
service:
  pipelines:
    profiles:
      receivers: [otlp]
      exporters: [otlp]

While this feature can be used now on the Collector, we do not yet recommend doing so in production: it is still under heavy development and is expected to have breaking changes, such as the ones mentioned above with OTLP.

However, this support in the Collector means that any receiver, processor or exporter of the Collector can now start adding profiles support, which we highly encourage to do, as a way to allow a smoother integration in the future, as well as to find potential issues early. If you wish to report a bug or contribute on this effort, you can view them on the contrib repository.

Semantic Conventions and Specification

To improve interoperability, the Profiling SIG worked also on OpenTelemetry Semantic Conventions for profiling. There is also ongoing work to introduce a profiling OpenTelemetry specification. This work will continue and should enable wide adoption across different platforms, tools and other OTel signals.

What’s next ?

Support for profiles in OpenTelemetry is moving very quickly, and while we’re still far from being able to provide a stable signal, we are happy to report that folks can start hacking with it, and integrate it within their modules.

If you’re interested in helping profiling move forward, or face issues when integrating with it, the Profiling SIG is always happy to get or provide help.

You can find us on #otel-profiles in the CNCF slack.