resource-meter

Crates.ioresource-meter
lib.rsresource-meter
version0.2.0
created_at2025-05-24 13:31:39.033931+00
updated_at2025-05-24 13:31:39.033931+00
descriptionA lightweight resource usage measurement library for Rust, providing scoped measurement of wall-clock time, user CPU time, and system CPU time.
homepagehttps://github.com/enterprise-search/resource-meter
repositoryhttps://github.com/enterprise-search/resource-meter
max_upload_size
id1687420
size12,881
Max Z (oxnz)

documentation

https://docs.rs/resource-meter

README

resource-meter

A lightweight resource usage measurement library for Rust, providing scoped measurement of wall-clock time, user CPU time, and system CPU time.

Features

  • Scoped measurement using a stack-based API
  • Hierarchical (tree) and flat reporting
  • Tracks wall time, user CPU time, and system CPU time
  • Simple API for integration
  • Platform support for Unix-like systems (uses libc::getrusage)

Example

use resource_meter::ResourceMeterStack;
use std::thread::sleep;
use std::time::Duration;

fn main() {
    // Create a stack to manage resource measurement scopes
    let mut stack = ResourceMeterStack::new();

    // Start a measurement scope named "outer"
    stack.push("outer");
    sleep(Duration::from_millis(100));

    // Start a nested measurement scope named "outer/inner"
    stack.push("outer/inner");
    sleep(Duration::from_millis(200));
    stack.pop(); // End "outer/inner"

    sleep(Duration::from_millis(50));
    stack.pop(); // End "outer"

    // Generate and print a hierarchical report
    let report = stack.finish();
    println!("{}", report);
}
Commit count: 0

cargo fmt