Emitting via OTLP

You can use emit_otlp to emit diagnostic events to remote OpenTelemetry-compatible services.

OpenTelemtry defines a wire protocol for exchanging diagnostic data called OTLP. If you're using a modern telemetry backend then chances are it supports OTLP either directly or through OpenTelemetry's Collector.

emit_otlp is an independent implementation of OTLP that maps emit's events onto the OpenTelemetry data model. emit_otlp doesn't rely on the OpenTelemtry SDK or any gRPC or protobuf tooling, so can be added to any Rust application without requiring changes to your build process.

[dependencies.emit_otlp]
version = "0.11.5"
extern crate emit;
extern crate emit_otlp;
fn main() {
    let rt = emit::setup()
        .emit_to(emit_otlp::new()
            // Add required resource properties for OTLP
            .resource(emit::props! {
                #[emit::key("service.name")]
                service_name: "my_app",
            })
            // Configure endpoints for logs/traces/metrics using gRPC + protobuf
            .logs(emit_otlp::logs_grpc_proto("http://localhost:4319"))
            .traces(emit_otlp::traces_grpc_proto("http://localhost:4319"))
            .metrics(emit_otlp::metrics_grpc_proto("http://localhost:4319"))
            .spawn())
        .init();

    // Your app code goes here

    rt.blocking_flush(std::time::Duration::from_secs(30));
}

See the crate docs for more details.

Logs

Any event can be treated as a log event. You need to configure a logs endpoint in your emit_otlp setup for this to happen. See the crate docs for details.

Traces

Events in emit's tracing data model can be treated as a trace span. You need to configure a traces endpoint in your emit_otlp setup for this to happen, otherwise they'll be treated as logs. See the crate docs for details.

Metrics

Events in emit's metrics data model can be treated as a metric. You need to configure a metrics endpoint in your emit_otlp setup for this to happen, otherwise they'll be treated as logs. See the crate docs for details.

Supported protocols

emit_otlp supports sending OTLP using gRPC, HTTP+protobuf, and HTTP+JSON.

TLS

emit_otlp supports TLS using the default Cargo features when your endpoint uses the https scheme. See the crate docs for details.

Compression

emit_otlp will compress payloads using gzip using the default Cargo features. See the crate docs for details.

HTTP headers

emit_otlp supports custom HTTP headers per endpoint. See the crate docs for details.