Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/spezifisch/ifstat-rs

ifstat reimplemented in rust, as a bit
https://github.com/spezifisch/ifstat-rs

ifstat linux macos network rust speed stats traffic windows

Last synced: 2 months ago
JSON representation

ifstat reimplemented in rust, as a bit

Awesome Lists containing this project

README

        

# ifstat-rs

`ifstat-rs` is a straightforward and efficient Rust tool to report network interface stats, similar to [ifstat](http://gael.roualland.free.fr/ifstat/).

[![tests](https://github.com/spezifisch/ifstat-rs/actions/workflows/test.yml/badge.svg)](https://github.com/spezifisch/ifstat-rs/actions/workflows/test.yml)
[![builds](https://github.com/spezifisch/ifstat-rs/actions/workflows/build.yml/badge.svg)](https://github.com/spezifisch/ifstat-rs/actions/workflows/build.yml)

## Features

- **Real-time Monitoring:** Parses and displays RX and TX bytes for each network interface every second.
- **Interface Flexibility:** Monitor specific interfaces, all interfaces, or just loopback interfaces.
- **Configurable Updates:** Set delays between updates and limit the number of updates.
- **Interface Listing with Friendly Names:** Displays friendly names for interfaces where supported (currently Windows).

## Supported Platforms

- **Linux:** Fully supported with real-time network statistics from `/proc/net/dev`.
- **Windows:** Supported as of v2.0.0.
- **macOS:** Supported as of v3.0.0.

## Installation

To install `ifstat-rs`, ensure you have Rust and Cargo installed.
Choose option A or B:

### A: Release from crates.io

```sh
cargo install ifstat-rs
```

### B: Install from Development Git Repository

```sh
cargo build --release
sudo cp target/release/ifstat-rs /usr/local/bin/
ifstat-rs --version
```

## Usage

### Options

**ifstat-rs**

- `-a`: Monitor all interfaces.
- `-l`: Include loopback interfaces.
- `-z`: Hide inactive interfaces where the counter stays zero.
- `-i `: Specify interfaces to monitor, separated by commas (e.g., `-i eth0,lo`).
- `--list-interfaces`: List all interfaces, with their friendly names where supported (currently Windows).
- `--first-measurement `: Set delay before the first measurement (default is the same as --delay).
- ``: Delay between updates in seconds (default is 1 second).
- ``: Number of updates before stopping (default is unlimited).

By default, ifstat-rs shows all interfaces excluding "lo".

### Examples

Default usage:

```console
$ ifstat-rs
eth0
KB/s in KB/s out
8724.76 225.89
10356.68 259.95
13281.06 294.90
```

Monitor specific interfaces:

```sh
# Linux/Mac-style
ifstat-rs -i eth0,wlan1
# Windows-style
ifstat-rs -i "\DEVICE\TCPIP_{66963456-C690-4E4E-940B-E7C915B9A07D},\DEVICE\TCPIP_{97D92124-3AC3-45B5-8634-F6547F9676CE}"
```

Lookup list of interfaces, (on Windows: with Adapter Names where present):

```console
$ ifstat-rs --list-interfaces
3 adapters:
\DEVICE\TCPIP_{66963456-C690-4E4E-940B-E7C915B9A07D} Ethernet
\DEVICE\TCPIP_{3CE6ABDA-3928-11EF-BFD9-806E6F6E6963} Loopback Pseudo-Interface 1
\DEVICE\TCPIP_{97D92124-3AC3-45B5-8634-F6547F9676CE} vEthernet (nat)
16 interfaces:
[...]
\DEVICE\TCPIP_{97D92124-3AC3-45B5-8634-F6547F9676CE} (vEthernet (nat))
\DEVICE\TCPIP_{66963456-C690-4E4E-940B-E7C915B9A07D} (Ethernet)
\DEVICE\TCPIP_{34DB3D4C-C1FC-4CDF-8BB2-9A7B1D40D640}
\DEVICE\TCPIP_{3CE6ABDA-3928-11EF-BFD9-806E6F6E6963} (Loopback Pseudo-Interface 1)
[...]
```

Monitor all interfaces, measure every second, for 10 seconds:

```sh
ifstat-rs -a 1 10
```

Include loopback interfaces:

```sh
ifstat-rs -l
```

Specify delay and count - first measure after 1 second, then every 60 seconds:

```sh
ifstat-rs -a --first-measurement 1 60
```

### Development

Run the tool with:

```sh
cargo run -- -a
```

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

*"This project has been generated with the assistance of ChatGPT. Please be aware that ChatGPT can make mistakes. It is important to review and verify all information provided by the tool."* is what it says. Just so you know. Because I guess maybe all the bugs aren't my fault after all.