Skip to main content

A btop-style terminal UI for monitoring a vLLM instance and its GPU in real time.

Project description

vllmtop/vllmpytop

PyPI Python versions License: MIT

Inspired by the excellent TUI style and functionality of btop, vllmtop is a CLI resource monitor for a vLLM instance and its GPU in real time. Simple braille charts, a responsive curses layout, and a non-blocking background poller so the UI never stalls on network or NVML latency.

tui

Quickstart

pip install vllmpytop    # install from pypi
vllmtop                  # or vllmpytop

What it shows

  • GPU: utilisation %, VRAM used/total, temperature, power draw vs. limit, SM clock, fan speed — with green/yellow/red thresholds. Its chart is a btop-style mirrored graph: GPU utilisation grows up from a centre line (positionally coloured green→red), and the request count grows down from it as a stacked two-band series — running (green) nearest the centre, waiting (magenta) beyond. The right side of the panel carries a compact vLLM column separated by a divider: the served model (● awake / ○ sleeping), uptime, KV-cache precision (cache_dtype), total requests served, prefix-caching on/off, KV blocks, GPU-memory target, and run/wait/kv bars.
  • Throughput: generation tok/s and prompt tok/s (rates derived from vLLM counters), as a mirrored chart in btop's network colours — gen (purple) grows up from the centre line, prompt/prefill (pink) grows down — each half fading dark at the baseline to bright at the peak. A stats column on the right shows current and peak values for both.
  • Requests: a live feed of inference calls, newest first (like btop's process list). When a log source is configured (--docker <container> or --log-file <path>) and vLLM runs with --enable-log-requests, each row shows the request age, prompt text (truncated), request ID, and max_tokens. Without --enable-log-requests the feed still shows entries but without prompt text. With no log source, a hint reminds you to enable one.
  • Perf (recent average over the last poll interval — far more useful live than the cumulative average): TTFT, inter-token (TPOT), end-to-end, and queue latencies as colour-coded braille sparklines, each with a right-aligned value column. Below a ┄ per-request ┄ divider: per-request prompt tokens, generation tokens, prefill time, and decode time. Fills remaining space with the KV-cache usage gradient chart and prefix-cache hit rate.

Data comes from vLLM's Prometheus /metrics endpoint plus in-process NVML polling. If vLLM goes away (e.g. a container restart) the UI shows a disconnect banner and keeps the GPU panel live, then reconnects automatically.

Install

Available on PyPI: pypi.org/project/vllmpytop.

Requires Python 3.10+ on Linux (curses is stdlib). A working NVIDIA driver is needed for the GPU panel.

install from pypi

pip install vllmpytop

install locally

# locally from a checkout:
pip install .

# / for development:
pip install -e ".[dev]"

This installs two equivalent commands — vllmpytop and the shorter alias vllmtop.

Dependencies: nvidia-ml-py (NVML bindings) and prometheus-client (exposition parser). The /metrics fetch uses stdlib urllib.

Usage

vllmtop                            # monitor http://localhost:8000
vllmtop --url http://host:8000     # a remote vLLM server
vllmtop --interval 0.5             # poll twice a second
vllmtop --no-gpu                   # skip the GPU panel
vllmtop --docker vllm-server       # + call feed in the requests panel (docker logs)
vllmtop --log-file /var/log/vllm.log   # + call feed from a log file
python -m vllmpytop                # same thing, without the entry point

The server URL can also be set via the VLLMTOP_URL environment variable. The log file path and Docker container can be set via VLLMTOP_LOG_FILE and VLLMTOP_DOCKER respectively.

Options

Flag Default Description
--url http://localhost:8000 vLLM base URL (env VLLMTOP_URL)
--interval 1.0 poll interval in seconds (0.2–10.0, also toggled with + / -)
--gpu-index 0 NVML GPU index
--no-gpu off disable the GPU panel
--docker stream docker logs -f <container> for the requests call feed (env VLLMTOP_DOCKER)
--log-file tail this vLLM log file for the requests call feed (env VLLMTOP_LOG_FILE)
--dump-json off collect two snapshots, print derived metrics as JSON, exit (no TTY)

Keybindings

Key Action
q / Esc quit
+ / - faster / slower refresh
p pause / resume polling
14 toggle a panel on/off (¹gpu ²throughput ³requests ⁴perf)
h / ? toggle help overlay

Each panel's title carries a superscript number (btop-style) showing the key that toggles it. Hiding panels reflows the rest to fill the freed space.

Headless smoke test

--dump-json collects two snapshots an interval apart (so rates are populated), prints the result as JSON, and exits. Works without a TTY — handy for CI or verifying connectivity:

python -m vllmpytop --dump-json --url http://localhost:8000

How it works

  • A background poller thread scrapes /metrics and polls NVML every interval seconds, storing the latest combined snapshot under a lock. This keeps all I/O latency off the render path.
  • The UI loop wakes on a short tick (250 ms), reads the latest snapshot, appends derived values (rates, recent-average latencies) to per-series ring buffers, and redraws — so render cadence is independent of poll cadence.
  • Counters → rates: Δvalue / Δt, guarded against Δt ≤ 0 and counter resets. Histograms → recent average: Δsum / Δcount between polls.
  • Braille charts: each cell is a 2×4 Unicode braille dot matrix, giving 2w × 4h-dot resolution for the smooth btop look.

Development

pytest        # parser-against-fixture, rate math, braille rendering

License

MIT — see LICENSE.

Project details


Download files

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

Source Distribution

vllmpytop-0.3.0.tar.gz (42.7 kB view details)

Uploaded Source

Built Distribution

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

vllmpytop-0.3.0-py3-none-any.whl (42.0 kB view details)

Uploaded Python 3

File details

Details for the file vllmpytop-0.3.0.tar.gz.

File metadata

  • Download URL: vllmpytop-0.3.0.tar.gz
  • Upload date:
  • Size: 42.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for vllmpytop-0.3.0.tar.gz
Algorithm Hash digest
SHA256 3fb9b923c6a131280d5a7159a2f8a7110616450c9857ba2ffda1f3c6e2ea9134
MD5 559ae012da88142df95d5bd6e7c792cc
BLAKE2b-256 e20ff9751996cc6ec4e05b99dc325687815d9b2d91d02d0649bb710dabcd1d4e

See more details on using hashes here.

File details

Details for the file vllmpytop-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: vllmpytop-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 42.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for vllmpytop-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5ac765e5e78ae168cc0f4c1f878cf714354b638f7333c778b90e9ebb0ba51d2b
MD5 768e0251abd6531996e26cd732e24d88
BLAKE2b-256 fe413a0ae2e7e673d06e82be85a1ccf9c93efabe1509fca68a207484f62f8848

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