A system handler to interact with processes.
Support the following platforms:
It also compiles for Android but never been tested on it.
It'll be difficult to build on Raspberry. A good way-around is to be build on Linux before sending it to your Raspberry:
bash
rustup target add armv7-unknown-linux-gnueabihf
cargo build --target=armv7-unknown-linux-gnueabihf
You have an example into the examples
folder. Just run cargo run
inside the examples
folder to start it. Otherwise, here is a little code sample:
```rust extern crate sysinfo;
use sysinfo::{NetworkExt, System, SystemExt};
let mut sys = System::new();
// We display the disks: println!("=> disk list:"); for disk in sys.get_disks() { println!("{:?}", disk); }
// Network data: println!("input data : {} B", sys.getnetwork().getincome()); println!("output data: {} B", sys.getnetwork().getoutcome());
// Components temperature: for component in sys.getcomponentslist() { println!("{:?}", component); }
// Memory information: println!("total memory: {} kB", sys.gettotalmemory()); println!("used memory : {} kB", sys.getusedmemory()); println!("total swap : {} kB", sys.gettotalswap()); println!("used swap : {} kB", sys.getusedswap());
// Number of processors println!("NB processors: {}", sys.getprocessorlist().len());
// To refresh all system information: sys.refresh_all(); ```
It's possible to use this crate directly from C. Take a look at the Makefile
and at the examples/src/simple.c
file.
To build the C example, just run:
```bash
make ./simple
If needed:
LDLIBRARYPATH=target/release/ ./simple ```
You can run the benchmarks locally with rust nightly by doing:
```bash
cargo bench ```
Here are the current results:
Linux
text
test bench_new ... bench: 12,610,204 ns/iter (+/- 453,957)
test bench_refresh_all ... bench: 3,339,360 ns/iter (+/- 400,590)
test bench_refresh_cpu ... bench: 12,785 ns/iter (+/- 603)
test bench_refresh_disk_lists ... bench: 49,465 ns/iter (+/- 3,516)
test bench_refresh_disks ... bench: 2,288 ns/iter (+/- 21)
test bench_refresh_memory ... bench: 11,252 ns/iter (+/- 801)
test bench_refresh_network ... bench: 21,960 ns/iter (+/- 3,423)
test bench_refresh_process ... bench: 20,526 ns/iter (+/- 703)
test bench_refresh_processes ... bench: 3,069,889 ns/iter (+/- 324,993)
test bench_refresh_system ... bench: 48,788 ns/iter (+/- 1,500)
test bench_refresh_temperatures ... bench: 23,076 ns/iter (+/- 1,371)
Windows
text
test bench_new ... bench: 61,548,071 ns/iter (+/- 196,093,742)
test bench_refresh_all ... bench: 2,541,951 ns/iter (+/- 482,285)
test bench_refresh_cpu ... bench: 460 ns/iter (+/- 478)
test bench_refresh_disk_lists ... bench: 152,940 ns/iter (+/- 8,330)
test bench_refresh_disks ... bench: 55,597 ns/iter (+/- 9,629)
test bench_refresh_memory ... bench: 2,130 ns/iter (+/- 486)
test bench_refresh_network ... bench: 212 ns/iter (+/- 216)
test bench_refresh_process ... bench: 38 ns/iter (+/- 33)
test bench_refresh_processes ... bench: 2,175,034 ns/iter (+/- 315,585)
test bench_refresh_system ... bench: 2,508 ns/iter (+/- 224)
test bench_refresh_temperatures ... bench: 1 ns/iter (+/- 0)
OSX
text
test bench_new ... bench: 64,062,254 ns/iter (+/- 8,845,126)
test bench_refresh_all ... bench: 4,285,670 ns/iter (+/- 467,963)
test bench_refresh_cpu ... bench: 10,712 ns/iter (+/- 1,493)
test bench_refresh_disk_lists ... bench: 837,489 ns/iter (+/- 48,593)
test bench_refresh_disks ... bench: 956 ns/iter (+/- 128)
test bench_refresh_memory ... bench: 3,327 ns/iter (+/- 462)
test bench_refresh_network ... bench: 34,465 ns/iter (+/- 5,228)
test bench_refresh_process ... bench: 3,935 ns/iter (+/- 1,135)
test bench_refresh_processes ... bench: 2,489,203 ns/iter (+/- 140,567)
test bench_refresh_system ... bench: 741,774 ns/iter (+/- 335,431)
test bench_refresh_temperatures ... bench: 680,362 ns/iter (+/- 167,343)
If you appreciate my work and want to support me, you can do it here: