#axum #timing #header #server-timing #applications #server-timings

axum-server-timings

Simplify adding the server-timings header to your Axum applications

1 unstable release

0.2.0 Jan 2, 2025

#148 in Profiling

Download history 102/week @ 2024-12-28 33/week @ 2025-01-04

135 downloads per month

MIT license

10KB
120 lines

axum-server-timings

Time your axum handlers with just a method call!

ServerTimings allows you to instantiate one struct and automatically get a header with all your timing data inserted, for use in browser devtools for performance testing.

The duration between calls to record is recorded automatically.

async fn handler() -> (ServerTimings, &'static str) {
    let mut timings = ServerTimings::new();
    tokio::time::sleep(Duration::from_secs_f32(0.1)).await;
    timings.record("wait", "How long the sleep took");
    tokio::time::sleep(Duration::from_secs_f32(0.5)).await;
    timings.record("wait2", "How long the second sleep took");
    (timings, "timings test")
}

How do I hide this in production?

RUSTFLAGS="--cfg hide_server_timings"

Dependencies

~1.5MB
~29K SLoC