Command-line system obervation tool.
sot is a Command-line System Obervation Tool in the spirit of top. It displays various interesting system stats and graphs them. Works on all operating systems.
One-line installer for macOS and Linux - Automatically detects your environment and installs all dependencies:
curl -fsSL https://raw.githubusercontent.com/anistark/sot/main/install.sh | bashThis script will:
- ✅ Detect your operating system
- ✅ Check for Python 3.10+ (installs if missing)
- ✅ Install pipx (if not present)
- ✅ Install sot and configure PATH
- ✅ Verify the installation
Note: This installation script does not work on Windows. Windows users should use one of the alternative installation methods below.
Using brew
brew tap anistark/tools
brew install sotOr single line:
brew install anistark/tools/sotUpdate using:
brew update && brew upgrade sotUsing pipx
Install and run with pipx. Setup pipx before proceeding.
python3 -m pipx install sot
python3 -m pipx ensurepath
sudo pipx ensurepath --globalor in single line:
python3 -m pipx install sot && python3 -m pipx ensurepath && sudo pipx ensurepath --globalUsing DEB Package (Experimental - Debian/Ubuntu)
### Using DEB Package (Experimental - Debian/Ubuntu)uv or pipx for recommended installation.
Download the latest DEB package from the releases page and install:
# Download latest .deb file from releases
wget https://github.com/anistark/sot/releases/latest/download/sot-*.deb
# Install the package
sudo dpkg -i sot-*.deb
# Install any missing dependencies (if needed)
sudo apt-get install -fUsing RPM Package (Experimental - RHEL/CentOS/Fedora)
uv or pipx for recommended installation.
Download the latest RPM package from the releases page and install:
# Download latest .rpm file from releases
wget https://github.com/anistark/sot/releases/latest/download/sot-*.rpm
# Install the package
sudo rpm -ivh sot-*.rpmFor enhanced security, verify GPG signatures before installing packages:
# Import the public signing key (one time setup)
curl -fsSL https://github.com/anistark/sot/releases/latest/download/public-key.asc | gpg --import
# For DEB packages:
dpkg-sig --verify sot-*.deb
# Or verify using detached signature
gpg --verify sot-*.deb.asc sot-*.deb
# Verify checksums
gpg --verify SHA256SUMS.sig && sha256sum -c SHA256SUMS
# For RPM packages:
gpg --verify sot-*.rpm.asc sot-*.rpm
# Verify checksums
gpg --verify SHA256SUMS-RPM.sig && sha256sum -c SHA256SUMS-RPMGPG Key Fingerprint: DCD1 9CA3 2C3F ACAA 1360 1C78 F4D7 EFDB 552E 84C9
Install from source
For testing or installing the latest version from source directly on your system.
Using uv (Recommended):
# Clone the repository
git clone https://github.com/anistark/sot.git
cd sot
# Install from source (system-wide)
uv pip install --system .
# Run from anywhere
sotUsing pipx:
# Clone the repository
git clone https://github.com/anistark/sot.git
cd sot
# Install from source using pipx
pipx install .
# Run from anywhere
sotRun with:
sot- CPU Usage
- Per Core and Thread level
- Processes with ID, threads, memory and cpu usage
- Interactive Order By: Press
Oto enter order by mode, navigate columns with arrow keys, toggle sort direction with Enter (DESC ↓ → ASC ↑ → OFF → cycle)
- Interactive Order By: Press
- Interactive Disk TUI - View all physical disks with partitions
- Real-time disk usage monitoring with accurate APFS container calculations
- Visual usage bars and percentage indicators
- I/O statistics (read/write counts and bytes)
- Disk Usage
- Per Read/Write
- Capacity
- Free
- Used
- Total
- Percent
- Memory Usage
- Capacity
- Free
- Available
- Used
- Swap
- Local IP
- Upload/Download Speed
- Bandwidth
- Network Usage
- Select Interface: Use
--net/-Nto monitor a specific network interface
- Disk Selection: Use
--disk/-Dto monitor a specific volumesot --disk- Interactive picker with arrow keyssot --disk /Volumes/External- Monitor specific volume
The sot info command displays comprehensive system information with a beautiful OS-specific ASCII logo.
sot info ,MMMM. Host - john@macbook.local
.MMMMMM Model - MacBook Pro
MMMMM, SKU - MK1E3LL/A
.;MMMMM:' MMMMMMMMMM;. Identifier - MacBookPro18,1
MMMMMMMMMMMMNWMMMMMMMMMMM: Serial - C02YX2QZMD6R
.MMMMMMMMMMMMMMMMMMMMMMMMWM.
MMMMMMMMMMMMMMMMMMMMMMMMM. OS - macOS 14.5.0 Sonoma
;MMMMMMMMMMMMMMMMMMMMMMMM: Kernel - 23.5.0
:MMMMMMMMMMMMMMMMMMMMMMMM: Firmware - 10151.121.3
.MMMMMMMMMMMMMMMMMMMMMMMMM. DE - Aqua
MMMMMMMMMMMMMMMMMMMMMMMMMMM. WM - Quartz Compositor
.MMMMMMMMMMMMMMMMMMMMMMMMMM. Shell - zsh
MMMMMMMMMMMMMMMMMMMMMMMM Terminal - iTerm.app (3.5.2)
;MMMMMMMMMMMMMMMMMMMM.
.MMMM,. .MMMM,. Chip - Apple M1 Pro (8P + 2E cores)
GPU - Apple M1 Pro (16 cores)
Memory - 8 GiB / 32 GiB
Displays - 2560 x 1600 Retina (Color LCD)
3840 x 2160@60.00Hz (Dell U2720Q)
Uptime - 12d 4h 23m
Battery - 87% & Discharging
The info command displays detailed system information organized into logical sections:
System Information
- Host (user@hostname)
- Model name (e.g., MacBook Pro)
- SKU/Model number
- Model identifier
- Serial number
Software
- Operating system with version name (e.g., macOS 15.6.1 Sequoia)
- Kernel version
- Firmware version
- Desktop Environment (DE)
- Window Manager (WM)
- Shell
- Terminal emulator
Hardware
- Chip details with performance/efficiency core breakdown (e.g., Apple M1 Pro with 6P + 2E cores)
- GPU model with core count
- Memory (used / total)
Displays
- All connected displays with resolutions, refresh rates, and display names
- Screen brightness (when available)
Status
- System uptime
- Battery status (percentage and charging state)
The command automatically detects your operating system and distribution, displaying the appropriate ASCII logo:
macOS: Apple logo
Linux Distributions:
- Ubuntu
- Debian
- Fedora
- Red Hat / RHEL
- Arch Linux
- Manjaro
- Pop!_OS
- CentOS
- Generic Linux/Tux (fallback)
Windows: Windows logo
The sot bench command allows you to measure disk performance with comprehensive benchmarks including sequential throughput, random IOPS, and latency distribution.
sot benchThis will display available disks and let you select one to benchmark interactively.
# Benchmark with default 10 second duration per test
sot bench
# Specify custom duration (in seconds)
sot bench --duration 5 # Quick 5-second benchmark
sot bench -d 30 # Longer 30-second benchmark for more stable results
# Specify custom output file
sot bench --output results.json
# Combine options
sot bench --duration 20 --output bench_results.jsonThe benchmarking tool runs four comprehensive tests:
- Sequential Read - Measures sustained read throughput (MB/s)
- Sequential Write - Measures sustained write throughput (MB/s)
- Random Read IOPS - Measures random read operations per second
- Random Write IOPS - Measures random write operations per second
Each test runs for the specified duration (default: 10 seconds) and provides detailed metrics:
- Throughput/IOPS measurements
- Min/Avg/Max latencies
- p50, p95, p99 percentile latencies
- Total test duration
The --duration flag controls how long each test runs:
- Default: 10 seconds - Quick, reliable measurements for most use cases
- Shorter durations (5s) - Very quick benchmarks for rapid testing
- Longer durations (30s+) - More stable results, accounts for system variance better
For all options, see
sot -Husage: sot [--help] [--version] [--log LOG] [--net NET] [--disk [DISK]] {info,bench,disk} ...
Command-line System Obervation Tool ≈
commands: {info,bench,disk}
info Display system information
bench Disk benchmarking
disk Interactive disk information viewer
options:
--help, -H Show this help message and exit.
--version, -V Display version information with styling
--log LOG, -L LOG Debug log file path (enables debug logging)
--net NET, -N NET Network interface to display (default: auto-detect best interface)
--disk [DISK], -D [DISK] Disk mountpoint to display (use without value for interactive selection)
For benchmark-specific options:
sot bench -husage: sot bench [-h] [--output OUTPUT] [--duration DURATION]
options:
-h, --help show this help message and exit
--output OUTPUT, -o OUTPUT
Output file for benchmark results (JSON format)
--duration DURATION, -d DURATION
Duration for each benchmark test in seconds (default: 10s)
Main Theme:
| Color | Hex | RGB |
|---|---|---|
| sky_blue3 | #5fafd7 |
rgb(95,175,215) |
| aquamarine3 | #5fd7af |
rgb(95,215,175) |
| yellow | #808000 |
rgb(128,128,0) |
| bright_black | #808080 |
rgb(128,128,128) |
| slate_blue1 | #875fff |
rgb(135,95,255) |
| red3 | #d70000 |
rgb(215,0,0) |
| dark_orange | #d75f00 |
rgb(215,95,0) |
All supported colors.
🏴 ≈ 🏴
sot uses:
Tested Systems:
If you use a system that's not listed above, feel free to add to the list. If you're facing any issues, would be happy to take a look.
Other top alternatives in alphabetical order:

