13 unstable releases (4 breaking)

0.5.0 Nov 23, 2024
0.4.0 Sep 18, 2024
0.3.0 Dec 24, 2023
0.2.0 Oct 4, 2023
0.1.3 Jan 31, 2023

#1045 in Development tools

Download history 69/week @ 2024-09-25 33/week @ 2024-10-02 26/week @ 2024-10-09 46/week @ 2024-10-16 10/week @ 2024-10-23 12/week @ 2024-10-30 15/week @ 2024-11-06 20/week @ 2024-11-13 139/week @ 2024-11-20 31/week @ 2024-11-27 91/week @ 2024-12-04 30/week @ 2024-12-11 16/week @ 2024-12-18 5/week @ 2024-12-25 10/week @ 2025-01-01 41/week @ 2025-01-08

76 downloads per month

MIT license

27KB
442 lines

dd-tracing-layer

license crates.io docs.rs

A tracing layer that sends logs to the Datadog Log API.

It's mainly useful when you don't have access to your infrastructure and you cannot use the Datadog Agent or any other mean.

Requirements

You'll need a Datadog API Key for everything to work.

Endpoint

This crate uses the v2 logs endpoints and, by default, will try to send the logs to the US1 region.

You can easily change the region or provide a custom URL if needed.

Example

Here's a simple example of how to set it up and use it:

use dd_tracing_layer::DatadogOptions;
use tracing_subscriber::prelude::*;
use tracing::{instrument, subscriber};

#[instrument]
fn log(msg: &'static str) {
    tracing::info!("your message: {}", msg);
}

fn main() {
    let options = DatadogOptions::new("my-service", "my-datadog-api-key")
        .with_tags("env:dev");
    let dd = dd_tracing_layer::create(options);
    let subscriber = tracing_subscriber::registry()
        .with(tracing_subscriber::fmt::Layer::new().json())
        .with(dd);
    let _s = subscriber::set_default(subscriber);
    log("hello world!");
}

Caveats

The layer will send the logs either 5 seconds after the last log is received or when the buffer arrives to 1000 logs. This is basically due to a limitation in the Datadog API.

Dependencies

~10–22MB
~297K SLoC