10 releases

0.1.9 Oct 17, 2022
0.1.8 Aug 2, 2022
0.1.7 Jun 13, 2022
0.1.6 Apr 3, 2022
0.1.0 Dec 10, 2021

#19 in #hot-reload

Download history 14/week @ 2024-08-28 9/week @ 2024-09-04 10/week @ 2024-09-11 19/week @ 2024-09-18 55/week @ 2024-09-25 21/week @ 2024-10-02 26/week @ 2024-10-09 24/week @ 2024-10-16 15/week @ 2024-10-23 14/week @ 2024-10-30 4/week @ 2024-11-06 5/week @ 2024-11-13 11/week @ 2024-11-20 12/week @ 2024-11-27 14/week @ 2024-12-04 32/week @ 2024-12-11

70 downloads per month

Custom license

24KB
497 lines

pomfrit

Prometheus metrics exporter with hot reload

Example:

use pomfrit::formatter::*;

/// Your metrics as a struct
struct MyMetrics<'a> {
    ctx: &'a str,
    some_diff: u32,
    some_time: u32,
}

/// Describe how your metrics will be displayed
impl std::fmt::Display for MyMetrics<'_> {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        f.begin_metric("some_diff")
            .label("label1", self.ctx)
            .label("label2", "some value")
            .value(self.some_diff)?;

        f.begin_metric("some_time")
            .label("label1", self.ctx)
            .value(self.some_time)
    }
}

async fn my_app() {
    // Create inactive exporter
    let (exporter, writer) = pomfrit::create_exporter(None).await.unwrap();

    // Spawn task that will run in the background and write metrics
    writer.spawn(|buf| {
        buf.write(MyMetrics {
            ctx: "asd",
            some_diff: 123,
            some_time: 456,
        }).write(MyMetrics {
            ctx: "qwe",
            some_diff: 111,
            some_time: 444,
        });
    });

    // ...

    // Reload exporter config
    exporter.reload(Some(pomfrit::Config {
        collection_interval_sec: 10,
        ..Default::default()
    })).await.unwrap();
}

Why is it called pomfrit?

Pomfrit is fried potatoes. Something very simple and you order it in addition to the main course.

Dependencies

~0.4–9.5MB
~101K SLoC