jemallocator/jemalloc-ctl
Jay f260a80f21
*: bump 0.6.0 (#95)
Signed-off-by: Jay Lee <BusyJay@users.noreply.github.com>
2024-07-14 23:34:47 +08:00
..
src *: bump 0.6.0 (#95) 2024-07-14 23:34:47 +08:00
Cargo.toml *: bump 0.6.0 (#95) 2024-07-14 23:34:47 +08:00
LICENSE-APACHE add jemalloc-ctl 2019-02-27 09:39:39 +01:00
LICENSE-MIT add jemalloc-ctl 2019-02-27 09:39:39 +01:00
README.md *: extra cleanup (#3) 2020-07-22 15:39:21 +08:00
rustfmt.toml add rustfmt.toml 2019-02-27 09:39:39 +01:00

jemalloc-ctl

Travis-CI Status Latest Version docs

A safe wrapper over jemalloc's mallctl*() control and introspection APIs.

Documentation

Platform support

Supported on all platforms supported by the tikv-jemallocator crate.

Example


use std::thread;
use std::time::Duration;
use tikv_jemalloc_ctl::{stats, epoch};

#[global_allocator]
static ALLOC: tikv_jemallocator::Jemalloc = tikv_jemallocator::Jemalloc;

fn main() {
    // Obtain a MIB for the `epoch`, `stats.allocated`, and
    // `atats.resident` keys:
    let e = epoch::mib().unwrap();
    let allocated = stats::allocated::mib().unwrap();
    let resident = stats::resident::mib().unwrap();
    
    loop {
        // Many statistics are cached and only updated 
        // when the epoch is advanced:
        e.advance().unwrap();
        
        // Read statistics using MIB key:
        let allocated = allocated.read().unwrap();
        let resident = resident.read().unwrap();
        println!("{} bytes allocated/{} bytes resident", allocated, resident);
        thread::sleep(Duration::from_secs(10));
    }
}

License

This project is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in jemalloc-ctl by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.