
Winload
A lightweight, real-time CLI tool for monitoring network bandwidth and traffic, inspired by Linux's nload.
๐ English ๐ ็ฎไฝไธญๆ(ๅคง้) ๐ ็น้ซไธญๆ(ๅฐ็ฃ) ๐ ๆ่จๆ ๐ ๆฅๆฌ่ช ๐ ํ๊ตญ์ด
๐ Introduction
Winload brings an intuitive, visual network monitor to the modern terminal. It started as a Windows-focused tool to fill the nload gap, and now targets Linux and macOS as well.
๐ Acknowledgements
Winload is inspired by the classic ใnloadใ project by Roland Riegel. Many thanks for the original idea and experience. https://github.com/rolandriegel/nload
โจ Key Features
- Dual implementations
- Rust edition: fast, memory-safe, single static binaryโgreat for everyday monitoring.
- Python edition: easy to hack and extend for prototyping or integrations.
- Cross-platform: Windows, Linux, and macOS (x64 & ARM64).
- Real-time visualization: live incoming/outgoing graphs and throughput stats.
- Minimal UI: clean TUI that mirrors nload's ergonomics.
๐ Performance Benchmarks
โก Winload (Rust) achieves ~10ms startup and <2MB binary size, significantly outperforming Python and matching C++ nload in efficiency.
๐ง Run from Source
Python
# or clone from Gitee (faster in China Mainland):
# git clone https://gitee.com/vincent-zyu/winload.git
Rust
๐ Python Edition Installation
๐ก Implementation Note: Only PyPI and GitHub/Gitee provide Python edition.
Only Cargo provides Rust source code for local compilation.
All other package managers (Scoop, AUR, npm, APT, RPM) and GitHub Releases distribute Rust binaries only.
Python (pip)
# recommend use uv:
# https://docs.astral.sh/uv/getting-started/installation/
# https://gitee.com/wangnov/uv-custom/releases
๐ฅ Rust Edition Installation (recommended)
npm (cross-platform)
# Recommended (scoped)
# Alternative (unscoped)
# Alternative (GitHub Packages)
# on Windows, use win-nload to avoid conflict with System32\winload.exe
# on Linux/macOS, both winload and win-nload work
# or use npx directly
Includes 4 precompiled binaries for x86_64 & ARM64 across Windows, Linux, and macOS.
Cargo (Build from source)
Windows (Scoop)
๐ Scoop Bucket (GitHub) ๐ Scoop Bucket (Gitee)
scoop bucket add vincentzyu https://github.com/VincentZyuApps/scoop-bucket
# or from Gitee:
# scoop bucket add vincentzyu https://gitee.com/vincent-zyu/scoop-bucket
scoop update # optional: manually refresh bucket list before install
scoop install winload
# execute bin file
win-nload
Get-Command win-nload # Powershell
where win-nload # CMD
๐ก Recommended: use Windows Terminal instead of the legacy Windows Console for correct CJK character rendering and better TUI experience.
scoop bucket add versions scoop install windows-terminal-preview wtp๐ก All builds require Windows 10+ (Rust 1.77+ dropped Windows 7/8 support). Scoop and npm provide MSVC + Npcap for x86_64 and ARM64 by default. These builds now delay-load
wpcap.dll, reducing startup failures before--npcapis used, but loopback capture still requires Npcap installed on the system.
Arch Linux (AUR):
Debian & RedHat Distros / Termux (one-liner)
Supports Debian/Ubuntu and derivatives โ Linux Mint, Pop!_OS, Deepin, UOS, etc. (apt)
Supports Fedora/RHEL and derivatives โ Rocky Linux, AlmaLinux, CentOS Stream, etc. (dnf)
Also supports Termux on Android (aarch64)
|
๐จ๐ณ Gitee mirror (faster in China Mainland):
|
โ ๏ธ The two
curl ... | bashinstall scripts above support x86_64 / aarch64 systems with apt (Debian/Ubuntu), dnf (Fedora/RHEL), or Termux (Android). For other platforms, use npm (npm install -g @vincentzyuapps/winload) or Cargo (cargo install winload) instead.
macOS / Linux (Homebrew)
๐ Homebrew Formula (GitHub) ๐ Homebrew Formula (Gitee)
# or from Gitee (manual tap clone):
# git clone https://gitee.com/vincent-zyu/homebrew-tap.git "$(brew --prefix)/Library/Taps/vincentzyuapps/homebrew-tap"
&&
๐ก Homebrew supports macOS (Intel & Apple Silicon) and Linux (x86_64 & ARM64).
DEB (Debian/Ubuntu):
# Download the latest .deb from GitHub Releases
# or use apt (auto-resolves dependencies)
RPM (Fedora/RHEL):
Or download binaries directly from GitHub Releases.
โจ๏ธ Usage
Options
| Flag | Description | Default |
|---|---|---|
-t, --interval <MS> |
Refresh interval in milliseconds | 500 |
-a, --average <SEC> |
Average calculation window in seconds | 300 |
-d, --device <NAME> |
Default device name (partial match) | โ |
--title [TITLE] |
Add a title line above device header: no value shows winload <version>; empty string (or omitted) shows only the default device header |
โ |
-e, --emoji |
Enable emoji decorations in TUI ๐ | off |
-U, --unicode |
Use Unicode block characters for graph (โโโยท) | off |
-u, --unit <UNIT> |
Display unit: bit or byte |
bit |
-b, --bar-style <STYLE> |
Bar style: fill, color, or plain |
fill |
--in-color <HEX> |
Incoming graph color, hex RGB (e.g. 0x00d7ff) |
cyan |
--out-color <HEX> |
Outgoing graph color, hex RGB (e.g. 0xffaf00) |
gold |
-m, --max <VALUE> |
Fixed Y-axis max (e.g. 10M, 1G, 500K) โ conflicts with --smart-max |
auto |
--smart-max [SECS] |
Smart adaptive Y-axis: auto-decays after traffic spikes (default half-life: 10s) โ conflicts with --max |
off |
-n, --no-graph |
Hide graph, show stats only | off |
--hide-separator |
Hide the separator line (row of equals signs) | off |
--no-color |
Disable all TUI colors (monochrome mode) | off |
--npcap |
[Windows Rust Only] Capture loopback traffic via Npcap (recommended) | off |
--netlink |
[Linux/Android Rust Only] Use RTNETLINK instead of sysinfo (for Termux proot distro or restricted environments) | off |
--debug-info |
Print network interface debug info and exit | โ |
-h, --help |
Print help (--help --emoji for emoji version!) |
โ |
-V, --version |
Print version | โ |
Y-axis scaling modes โ there are three mutually exclusive scenarios:
Mode Flag Behavior Fixed max --max <VALUE>Y-axis is locked to the specified value (e.g. 10M,1G).Smart max --smart-max [SECS]Y-axis adapts automatically: jumps up on traffic spikes, then smoothly decays back down (exponential decay, default half-life 10 s). History peak (neither flag) Y-axis follows the historical maximum of each metric โ the default behavior. โ ๏ธ
--maxand--smart-maxconflict with each other โ you can only use one at a time.
Keyboard Shortcuts
| Key | Action |
|---|---|
โ / โ or โ / โ |
Switch network device |
F3 |
Toggle debug info overlay (Minecraft-style) |
= |
Toggle separator line visibility |
c |
Toggle color on/off |
q / Esc |
Quit |
๐ช Windows Loopback (127.0.0.1)
Windows cannot report loopback traffic through standard APIs โ this is a functional deficiency in Windows' network stack.
To capture loopback traffic on Windows, use the --npcap flag:
This requires Npcap installed with "Support loopback traffic capture" enabled during setup.
I previously tried polling Windows' own
GetIfEntryAPI directly, but the counters are always 0 for loopback โ there is simply no NDIS driver behind the loopback pseudo-interface to count anything. That code path has been removed.
๐ For a deep dive into why Windows loopback is broken, see docs/win_loopback.md
On Linux and macOS, loopback traffic works out of the box โ no extra flags needed.
On Linux/Android, if /proc/net/dev is not accessible (e.g. inside a Termux proot distro or other restricted environments), the Rust edition can use --netlink to collect network stats via RTNETLINK directly:
Note:
--netlinkis an opt-in backend, similar to--npcap; it is never enabled unless you pass the flag. Normal Linux/Android runs still use sysinfo by default. This flag is Linux/Android Rust edition only; the Python edition does not support--netlinkand continues to use psutil. macOS does not support netlink.๐ For a deep dive into Linux/Android network statistics collection, see docs/linux_android_netlink.md
๐ผ๏ธ Previews
Python Edition Preview

Rust Edition Preview

Rust Edition Preview GIF

Terminal Recording
โ Recorded by asciinema
๐ฆ Dependencies
Python Edition
| Package | Version | Description |
|---|---|---|
| 3.13.11 | Programming language | |
| โฅ7.0 | Process and system utilities | |
| โฅ2.0 | Windows curses support |
Rust Edition
๐งญ Epilogue
Network traffic flows formless through the void โ yet Winload gives it shape. Packets traverse the terminal, silent and unseen, but through this window, every thread of throughput takes form before your eyes. If you seek to know the pulse of a machine's connection to the world, this tool is at once a humble lamp upon your desk and a guiding star for the journey ahead.