Exporters
In order to visualize and analyze your telemetry, you will need to export your data to an OpenTelemetry Collector or a backend such as Jaeger, Zipkin, Prometheus or a vendor-specific one.
As part of OpenTelemetry Go you will find many exporters being available. Among them, the OpenTelemetry Protocol (OTLP) exporters provide the best experience for you as an end-user, since it is a general-purpose telemetry data delivery protocol designed in the scope of the OpenTelemetry project.
To learn more about the OTLP protocol, you can read the OTLP Specification.
Below you will find some introductions on how to set up exporters for OTLP and other common protocols in your code.
Console
The console exporter is useful for development and debugging tasks, and is the simplest to set up.
Console traces
go.opentelemetry.io/otel/exporters/stdout/stdouttrace
contains an implementation of the console trace exporter.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/stdout/stdouttrace"
"go.opentelemetry.io/otel/sdk/trace"
)
func newExporter() (trace.SpanExporter, error) {
return stdouttrace.New()
}
Console metrics (Experimental)
go.opentelemetry.io/otel/exporters/stdout/stdoutmetric
contains an implementation of the console metrics exporter.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/stdout/stdoutmetric"
"go.opentelemetry.io/otel/sdk/metric"
)
func newExporter() (metric.Exporter, error) {
return stdoutmetric.New()
}
OTLP
To send trace data to an OTLP endpoint (like the collector or Jaeger >= v1.35.0) you’ll want to configure an OTLP exporter that sends to your endpoint.
To learn more on how to use the OTLP HTTP exporter, try the otel-collector example
OTLP traces over HTTP
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp
contains an implementation of the OTLP trace exporter using HTTP with binary
protobuf payloads.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp"
"go.opentelemetry.io/otel/sdk/trace"
)
func newExporter(ctx context.Context) (trace.SpanExporter, error) {
return otlptracehttp.New(ctx, client)
}
OTLP traces over gRPC
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc
contains an implementation of OTLP trace exporter using gRPC.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc"
"go.opentelemetry.io/otel/sdk/trace"
)
func newExporter(ctx context.Context) (trace.SpanExporter, error) {
return otlptracegrpc.New(ctx, client)
}
Jaeger
To try out the OTLP exporter, since v1.35.0 you can run Jaeger as an OTLP endpoint and for trace visualization in a Docker container:
docker run -d --name jaeger \
-e COLLECTOR_OTLP_ENABLED=true \
-p 16686:16686 \
-p 4317:4317 \
-p 4318:4318 \
jaegertracing/all-in-one:latest
OTLP metrics over HTTP (Experimental)
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp
contains an implementation of OTLP metrics exporter using HTTP with binary
protobuf payloads.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp"
"go.opentelemetry.io/otel/sdk/metric"
)
func newExporter(ctx context.Context) (metric.Exporter, error) {
return otlpmetrichttp.New(ctx)
}
OTLP metrics over gRPC (Experimental)
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetricgrpc
contains an implementation of OTLP metrics exporter using gRPC.
Here’s how you can create an exporter with default configuration:
import (
"go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetricgrpc"
"go.opentelemetry.io/otel/sdk/trace"
)
func newExporter(ctx context.Context) (metric.Exporter, error) {
return otlpmetricgrpc.New(ctx)
}
Prometheus (Experimental)
A Prometheus exporter is used to report metrics via Prometheus scrape HTTP endpoint.
go.opentelemetry.io/otel/exporters/prometheus
contains an implementation of Prometheus metrics exporter.
Here’s how you can create an exporter (which is also a metric reader) with default configuration:
import (
"go.opentelemetry.io/otel/exporters/prometheus"
"go.opentelemetry.io/otel/sdk/metric"
)
func newExporter(ctx context.Context) (metric.Reader, error) {
// prometheus.DefaultRegisterer is used by default
// so that metrics are available via promhttp.Handler.
return prometheus.New()
}
To learn more on how to use the Prometheus exporter, try the prometheus example
Available packages
You can find a full list of available exporters in the OpenTelemetry registry.