Skip to main content

Global nvitop: web-based GPU monitoring dashboard for all your remote servers via SSH

Project description

gnvitop logo

gnvitop

Global nvitop — a web-based GPU monitoring dashboard that monitors all your remote GPU servers from a single page.

PyPI Python License

960cd5fae22199ece06060e7ec8862a4

Like nvitop, but for all your servers at once, displayed as a beautiful web dashboard.

pip install gnvitop
gnvitop

How It Works

  1. Monitors local GPU automatically (no config needed)
  2. Reads your ~/.ssh/config and SSH into each remote server
  3. Runs nvidia-smi to collect GPU stats and per-GPU process/user info
  4. Displays everything in a real-time web dashboard with current user highlight
  5. Auto-refreshes every 30 seconds
graph LR
    A[gnvitop] --> B[Browser]
    B --> C["localhost — Local GPUs"]
    B --> D["Server A — 4x A100"]
    B --> E["Server B — 8x V100"]
    B --> F["Server C — 2x RTX 4090"]
    B --> G["Server D — offline"]

    style A fill:#7c3aed,stroke:none,color:#fff,font-weight:bold
    style B fill:#2563eb,stroke:none,color:#fff
    style C fill:#16a34a,stroke:none,color:#fff
    style D fill:#16a34a,stroke:none,color:#fff
    style E fill:#16a34a,stroke:none,color:#fff
    style F fill:#16a34a,stroke:none,color:#fff
    style G fill:#dc2626,stroke:none,color:#fff

Installation

pip install gnvitop

Usage

gnvitop                              # start and auto-open browser
gnvitop -p 8080                      # custom port
gnvitop --host 0.0.0.0              # expose to LAN
gnvitop --no-browser                 # don't auto-open browser
gnvitop --ssh-config /path/to/config # custom SSH config
gnvitop -v                           # show version

Or run as a module:

python -m gnvitop

Prerequisites

  1. SSH config -- your ~/.ssh/config should have server entries:
Host gpu-server-01
    HostName 192.168.1.101
    User alice
    IdentityFile ~/.ssh/id_rsa

Host gpu-server-02
    HostName 192.168.1.102
    User bob
  1. SSH key auth -- password-less login should be set up
  2. nvidia-smi -- must be installed on the remote servers

Features

  • Zero config -- reads ~/.ssh/config automatically, no setup needed
  • One command -- pip install gnvitop && gnvitop, that's it
  • Local + Remote -- monitors local GPU alongside all remote servers
  • Per-GPU users -- shows which users occupy each GPU and their memory usage
  • User highlight -- your own processes are highlighted in blue for quick identification
  • Auto browser -- opens dashboard in your browser on start
  • Real-time -- 30s auto-refresh with manual refresh button
  • Concurrent -- queries all servers in parallel (20 workers)
  • Fast loading -- background cache warming so the dashboard loads instantly; SSE streaming shows each server as it responds
  • Cached -- 30s cache to avoid hammering your servers
  • Dark UI -- clean, responsive dark-themed dashboard
  • At a glance -- summary bar shows online hosts, total GPUs, idle GPUs, free memory
  • Color coded -- green (online), yellow (no GPU), red (offline), blue (local)
  • GPU details -- utilization bars, memory bars, temperature with color alerts

Comparison with nvitop

Feature nvitop gnvitop
Monitor local GPU Yes Yes
Monitor remote GPUs No Yes
Multiple servers No Yes
Show per-GPU users Yes Yes
Highlight current user No Yes
Interface Terminal Web browser
Setup Run on each server Run once, reads SSH config

gnvitop is not a replacement for nvitop -- it's a complement. Use nvitop for detailed local process-level GPU monitoring, use gnvitop to get an overview of all your GPU servers (including local) from one place.

License

MIT

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

gnvitop-0.2.5.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

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

gnvitop-0.2.5-py3-none-any.whl (16.3 kB view details)

Uploaded Python 3

File details

Details for the file gnvitop-0.2.5.tar.gz.

File metadata

  • Download URL: gnvitop-0.2.5.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gnvitop-0.2.5.tar.gz
Algorithm Hash digest
SHA256 bedc0dd777ab959634f4264914b8ac55682f5ce6065c19b9425bb527bb154b19
MD5 f17ff1c194efbb0a4e44c6f7896f01a5
BLAKE2b-256 442c5d0f7fc6ce918935409acaa69705c94fa17365af87c03171176dbed4c8e3

See more details on using hashes here.

Provenance

The following attestation bundles were made for gnvitop-0.2.5.tar.gz:

Publisher: publish.yml on Linwei94/gnvitop

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gnvitop-0.2.5-py3-none-any.whl.

File metadata

  • Download URL: gnvitop-0.2.5-py3-none-any.whl
  • Upload date:
  • Size: 16.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gnvitop-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 661e1ebff72ce9a5b8c216bd7f8d341c8dbc460b1f8fc03f47512537fc21d940
MD5 854066856d1c284714b40cd17df9e0b2
BLAKE2b-256 d31fb6b9c2335219fea3910cd382fb3032c31f49921fa077e89eecfc5a757c3d

See more details on using hashes here.

Provenance

The following attestation bundles were made for gnvitop-0.2.5-py3-none-any.whl:

Publisher: publish.yml on Linwei94/gnvitop

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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