10 releases

0.0.2-alpha.1 Oct 16, 2023
0.0.1-alpha.11 Aug 4, 2023
0.0.1-alpha.9 Jul 31, 2023

#426 in Development tools

Download history 43/week @ 2023-12-22 48/week @ 2023-12-29 183/week @ 2024-01-05 237/week @ 2024-01-12 210/week @ 2024-01-19 341/week @ 2024-01-26 517/week @ 2024-02-02 116/week @ 2024-02-09 284/week @ 2024-02-16 244/week @ 2024-02-23 414/week @ 2024-03-01 263/week @ 2024-03-08 466/week @ 2024-03-15 375/week @ 2024-03-22 226/week @ 2024-03-29 537/week @ 2024-04-05

1,634 downloads per month
Used in 4 crates (3 directly)

MIT/Apache

84KB
2K SLoC

Project Forum Chat

License: MIT License: Apache-2.0

High-level Rust integration of opentelemetry metrics and InfluxDB.

Examples

Easy, zero-configuration InfluxDB as a child process

let tmp = tempfile::tempdir().unwrap();

// create our meter provider
let (_influxive, meter_provider) = influxive::influxive_child_process_meter_provider(
    influxive::InfluxiveChildSvcConfig::default()
        .with_database_path(Some(tmp.path().to_owned())),
    influxive::InfluxiveMeterProviderConfig::default(),
).await.unwrap();

// register our meter provider
opentelemetry_api::global::set_meter_provider(meter_provider);

// create a metric
let m = opentelemetry_api::global::meter("my.meter")
    .f64_histogram("my.metric")
    .init();

// make a recording
m.record(3.14, &[]);

Connecting to an already running InfluxDB system process

// create our meter provider
let meter_provider = influxive::influxive_external_meter_provider_token_auth(
    influxive::InfluxiveWriterConfig::default(),
    influxive::InfluxiveMeterProviderConfig::default(),
    "http://127.0.0.1:8086",
    "my.bucket",
    "my.token",
);

// register our meter provider
opentelemetry_api::global::set_meter_provider(meter_provider);

// create a metric
let m = opentelemetry_api::global::meter("my.meter")
    .f64_histogram("my.metric")
    .init();

// make a recording
m.record(3.14, &[]);

Dependencies

~10–24MB
~317K SLoC