Crates.io | effective-limits |
lib.rs | effective-limits |
version | 0.5.5 |
source | src |
created_at | 2020-02-22 00:37:26.595855 |
updated_at | 2022-11-20 21:45:16.476127 |
description | Estimate effective resource limits for a process e.g. how much RAM is available for use. |
homepage | |
repository | https://github.com/rbtcollins/effective-limits.rs |
max_upload_size | |
id | 211338 |
size | 115,522 |
effective-limits
is a mid-level API for determining the effective limits upon
a process. It combines e.g. mem_info
and getrlimit
.
The goal is to have a good chance of avoiding failed allocations without requiring either developer or user a-priori selection of memory limits. That is, how much memory is effectively available for this process to use, considering the physical machine and ulimits, but not the impact of noisy neighbours, swappiness and so on. This limit can then be used to inform the size of in memory caches, put a threshold on in or output file buffers and so on.
#![warn(clippy::all)]
extern crate effective_limits;
fn main() -> effective_limits::Result<()> {
println!("Effective mem limit: {}", effective_limits::memory_limit()?);
Ok(())
}