Integrating with OpenTelemetry

You can configure emit to send its diagnostics to the OpenTelemetry SDK using emit_opentelemetry. See the crate docs for more details.

Larger applications may find themselves integrating components using multiple diagnostic frameworks, like log or tracing. In these cases, you can use the OpenTelemetry SDK as your central pipeline, with others integrating with it instead of eachother.

flowchart
    log --> appender_log --> opentelemetry_sdk
    tracing --> tracing_opentelemetry --> opentelemetry_sdk
    emit --> emit_opentelemetry --> opentelemetry_sdk

    click emit href "https://docs.rs/emit/1.6.0/emit/macro.emit.html"
    click emit_opentelemetry href "https://docs.rs/emit_opentelemetry"
    click log href "https://docs.rs/log"
    click appender_log href "https://docs.rs/opentelemetry_appender_log"
    click tracing href "https://docs.rs/tracing"
    click tracing_opentelemetry href "https://docs.rs/tracing_opentelemetry"
    click opentelemetry_sdk href "https://docs.rs/opentelemetry_sdk"

Keep in mind that diagnostics from libraries you depend on aren't always useful or worth collecting. What the author of a library considers important isn't necessarily what you do in the context of your application. This is particularly true of tracing. If you don't control the code being traced, then any spans it produces are likely going to be noise that you can't meaningfully do anything with. Metrics can be an exception. They typically boil down the behavior of a component into a few key indicators that can give you a good idea of what it's doing, without bloating your own diagnostics.