Skip to main content

Network Load Monitor - nload-like TUI tool for Windows

Project description

winload onefetch

Winload

A lightweight, real-time CLI tool for monitoring network bandwidth and traffic, inspired by Linux's nload.

๐Ÿ“– English ๐Ÿ“– ็ฎ€ไฝ“ไธญๆ–‡(ๅคง้™†) ๐Ÿ“– ็น้ซ”ไธญๆ–‡(ๅฐ็ฃ) ๐Ÿ“– ๆ—ฅๆœฌ่ชž ๐Ÿ“– ํ•œ๊ตญ์–ด

GitHub Gitee

Windows x64 | ARM64 Linux x64 | ARM64 macOS x64 | ARM64 Android x64 | ARM64

PyPI npm Crates.io

Scoop AUR APT RPM Homebrew

๐Ÿ“– Build Docs

๐Ÿš€ 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 <5MB binary size, significantly outperforming Python and matching C++ nload in efficiency.

Winload Benchmark

๐Ÿ”ง Run from Source

Python

git clone https://github.com/VincentZyuApps/winload.git
# or clone from Gitee (faster in China Mainland):
# git clone https://gitee.com/vincent-zyu/winload.git
cd winload/py
pip install -r requirements.txt
python main.py

Rust

git clone https://github.com/VincentZyuApps/winload.git
cd winload/rust
cargo run --release
cargo run --release -- --help    # Show help
cargo run --release -- --version # Show version

๐Ÿ 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)

pip install winload
# recommend use uv:
# https://docs.astral.sh/uv/getting-started/installation/
# https://gitee.com/wangnov/uv-custom/releases
uv venv --python 3.13
uv pip install winload
uv run winload
uv run python -c "import shutil; print(shutil.which('winload'))"

๐Ÿ“ฅ Rust Edition Installation (recommended)

npm (cross-platform)

npm install -g @vincentzyuapps/winload
npm list -g @vincentzyuapps/winload
# 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
npx @vincentzyuapps/winload

โš ๏ธ The old package winload-rust-bin has been deprecated. Please use @vincentzyuapps/winload instead. The scoped package name is required for GitHub Packages compatibility.

Includes 6 precompiled binaries for x86_64 & ARM64 across Windows, Linux, and macOS.

Cargo (Build from source)

cargo install winload
cargo install --list

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 --npcap is used, but loopback capture still requires Npcap installed on the system. For other variants (MinGW, non-Npcap, i686), download from GitHub Releases.

Arch Linux (AUR):

paru -S winload-rust-bin
which winload

Linux (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)

curl -fsSL https://raw.githubusercontent.com/VincentZyuApps/winload/main/docs/install_scripts/install.sh | bash
which winload

๐Ÿ“„ View install script source

๐Ÿ‡จ๐Ÿ‡ณ Gitee mirror (faster in China Mainland):

curl -fsSL https://gitee.com/vincent-zyu/winload/raw/main/docs/install_scripts/install_gitee.sh | bash
which winload

๐Ÿ“„ View Gitee install script

โš ๏ธ The two curl ... | bash install 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)

brew tap vincentzyuapps/tap
# or from Gitee (manual tap clone):
# git clone https://gitee.com/vincent-zyu/homebrew-tap.git "$(brew --prefix)/Library/Taps/vincentzyuapps/homebrew-tap"
brew update && brew install winload
which winload

๐Ÿ’ก Homebrew supports macOS (Intel & Apple Silicon) and Linux (x86_64 & ARM64).

Manual install

DEB (Debian/Ubuntu):

# Download the latest .deb from GitHub Releases
sudo dpkg -i ./winload*.deb
# or use apt (auto-resolves dependencies)
sudo apt install ./winload*.deb
which winload

RPM (Fedora/RHEL):

sudo dnf install ./winload*.rpm
which winload

Or download binaries directly from GitHub Releases.

โŒจ๏ธ Usage

winload              # Monitor all active network interfaces
winload -t 200       # Set refresh interval to 200ms
winload -d "Wi-Fi"   # Start with a specific device
winload --title      # Show "winload <version>" as the header title
winload --title "My Monitor" # Use a custom header title
winload --title ""   # Keep the default device header
winload -e           # Enable emoji decorations ๐ŸŽ‰
winload --npcap      # Capture 127.0.0.1 loopback traffic (Windows, requires Npcap)

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
--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.

โš ๏ธ --max and --smart-max conflict 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:

winload --npcap

This requires Npcap installed with "Support loopback traffic capture" enabled during setup.

I previously tried polling Windows' own GetIfEntry API 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.

๐Ÿ–ผ๏ธ Previews

Python Edition Preview

docs/images/preview-py.png

Rust Edition Preview

docs/images/preview-rust.png

Rust Edition Preview GIF

docs/images/preview-rust.gif

Terminal Recording

winload demo

โ†‘ Recorded by asciinema

๐Ÿ“ฆ Dependencies

Python Edition

Package Version Description
Python 3.13.11 Programming language
psutil โ‰ฅ7.0 Process and system utilities
windows-curses โ‰ฅ2.0 Windows curses support

Rust Edition

Package Version Description
Rust 1.93.0 Programming language
ratatui 0.29 Terminal UI framework
crossterm 0.28 Cross-platform terminal library
sysinfo 0.32 System information library
clap 4 Command-line argument parser
pcap 2 Packet capture (optional, Windows)

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

winload-0.1.9b6.tar.gz (25.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

winload-0.1.9b6-py3-none-any.whl (41.2 kB view details)

Uploaded Python 3

File details

Details for the file winload-0.1.9b6.tar.gz.

File metadata

  • Download URL: winload-0.1.9b6.tar.gz
  • Upload date:
  • Size: 25.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for winload-0.1.9b6.tar.gz
Algorithm Hash digest
SHA256 3fcec459dd9e5bd64d2051e1bfdee029765ebfaeb915e5039376535a83cb0a3b
MD5 a14bd40e5e2603b750003560e33f1ce5
BLAKE2b-256 795a5e340bf858a29a062777802ce0adf4a6802caee8b9c6c51832ec07a6afc8

See more details on using hashes here.

File details

Details for the file winload-0.1.9b6-py3-none-any.whl.

File metadata

  • Download URL: winload-0.1.9b6-py3-none-any.whl
  • Upload date:
  • Size: 41.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for winload-0.1.9b6-py3-none-any.whl
Algorithm Hash digest
SHA256 a6ba3bf337d963d71c0677c5220222054fcc6c8c41922f5baa05410cd876ff42
MD5 9c04b819d8e9977c753366407ec39bc0
BLAKE2b-256 72d74a0044a79b7a609112ebbd4990010b2593bdbd2b71f1f9d7982602770304

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page