Skip to main content

A package that provides an aggregated view of the NVIDIA GPU information on several hosts.

Project description

nvidb

A package that provides an aggregated view of the NVIDIA GPU information on several hosts.

1. Installation

1.1 Install using pip

You can install nvidb using pip. First, clone the repository:

git clone https://github.com/FanBB2333/nvidb.git
cd nvidb
pip install .

Or install directly from PyPI:

pip install nvidb
# If the specified version is unavailable in your custom repository, use pypi.org as the source:
pip install nvidb -i https://pypi.org/simple

1.2 Configuration

Option A: Interactive Setup (Recommended)

Use the interactive command to add servers:

nvidb add

This will guide you through adding a new server with prompts for host, port, username, authentication method, etc.

Option B: Manual Configuration

To manually configure remote servers, create or edit the configuration file at ~/.nvidb/config.yml:

mkdir -p ~/.nvidb/
cp config.example.yml ~/.nvidb/config.yml
# Edit the file with your server details

Configuration file template:

servers:
  - hostname: "example1.com"       # Server hostname or IP address
    port: 22                       # SSH port number
    username: "user1"              # SSH username for authentication
    nickname: "Production GPU"     # Human-readable nickname for display
    auth: "auto"                   # Authentication method: auto | key | password
    identityfile: "~/.ssh/id_ed25519"  # Optional, used only when auth is auto/key

Configuration Options:

  • hostname: Server hostname or IP address (required)
  • port: SSH port, default is 22 (required)
  • username: SSH username (required)
  • nickname: Human-readable server nickname (optional)
  • auth: Authentication method - auto, key, or password (optional, default: auto)
  • identityfile: SSH private key path (optional, only effective when auth is auto or key)
  • password: SSH password (optional, will prompt if needed)

Warning: Storing passwords in plaintext in the configuration file is NOT RECOMMENDED for security reasons. Consider using SSH key-based authentication (auth: key) instead.

Environment Variables

You can customize the working directory by setting NVIDB_HOME:

export NVIDB_HOME=/path/to/custom/nvidb

Default working directory is ~/.nvidb/.


2. Usage

2.1 Basic Commands

nvidb                  # Monitor local GPU only (interactive TUI)
nvidb --remote         # Monitor local and remote servers
nvidb --once           # Print GPU stats once and exit
nvidb --once --remote  # Print all servers once and exit
nvidb --version        # Show version

2.2 Server Management

nvidb add              # Interactively add a new server
nvidb import [path]    # Import servers from SSH config (default: ~/.ssh/config)
nvidb info             # Show configuration info and server list

2.3 GPU Logging

Continuously log GPU statistics to an SQLite database:

nvidb log                          # Log local GPU with default settings
nvidb log --remote                 # Log local and remote GPUs
nvidb log --interval 10            # Set logging interval to 10 seconds
nvidb log --db-path /path/to/db    # Specify custom database path

Press Ctrl+C to stop logging and save data.

2.4 Web Dashboard

Open a Streamlit-based web dashboard to view live GPU info and browse log sessions:

pip install streamlit
nvidb web                 # Web dashboard (Live + Logs)
nvidb web --db-path /path/to/db
nvidb web --port 8502

After the server starts:

  • Switch to Logs and select a session from the left sidebar.
  • Use Live-local / Live-remote in the UI to toggle local-only vs local+remote live stats (remote is loaded only when Live-remote is selected).
  • Use Theme to switch Light / Dark.

nvidb log web is deprecated; use nvidb web instead.

2.5 Cleanup

Remove server configurations or delete log data:

nvidb clean              # Interactive cleanup menu
nvidb clean all          # Delete all data (requires double confirmation)

2.6 Interactive TUI Navigation

When viewing GPU stats, use these keyboard shortcuts:

Key Action
j / Move selection down
k / Move selection up
Enter / Space Toggle expand/collapse server
a Expand all servers
c Collapse all servers
q Quit

2.7 GPU Monitor Decorator

Use the @nvidb.monitor decorator to track GPU usage during function execution:

import nvidb

@nvidb.monitor
def train_model():
    # Your training code here
    pass

# With custom options
@nvidb.monitor(sample_interval=0.05, gpu_indices=[0, 1])
def multi_gpu_training(epochs: int = 100):
    pass

# Async function support
@nvidb.monitor
async def async_training():
    pass

After function execution, it outputs:

======================================================================
[nvidb.monitor] Function completed: train_model
  Signature: train_model()
  Location: /path/to/file.py:14
----------------------------------------------------------------------
  Duration: 125.3s
----------------------------------------------------------------------
  GPU 0: NVIDIA GeForce RTX 3090 Ti
    Memory:
      Peak:    8192.00 MiB / 24.00 GiB
      Delta:   +6144.00 MiB
    Utilization:
      Avg:     85.0%
    Temperature:
      Peak:    72C
    Power:
      Peak:    320.5W
======================================================================

Decorator Options:

  • sample_interval: Sampling interval in seconds (default: 0.1)
  • gpu_indices: List of GPU indices to monitor (default: all GPUs)
  • enabled: Enable/disable monitoring (default: True)

4. System Requirements

  • NVIDIA driver installed with nvidia-smi available in terminal
  • Python 3.8+
  • SSH access to remote servers (for remote monitoring)

5. Tips

  • Use nvidia-smi --help-query-gpu to see available query options
  • Database files are stored in ~/.nvidb/gpu_log.db by default
  • Configuration and logs are stored in ~/.nvidb/ directory

6. Show me the screenshots

  • Monitor local info with nvidb:

nvidb local

  • Monitor remote info with nvidb --remote:

nvidb remote

  • Monitor on web panel with nvidb web:

Local info:

nvidb web local

Remote info:

nvidb web remote


7. Acknowledgements

  • Thanks to NVIDIA for providing the nvidia-smi tool, which is used to query GPU information.
  • Thanks to nvidia-ml-py (pynvml) for Python bindings to NVML, used by the @nvidb.monitor decorator.
  • Thanks to Paramiko for powering SSH connections for remote monitoring.
  • Thanks to PyYAML for YAML-based configuration loading and saving.
  • Thanks to pandas for parsing and processing GPU stats and log data.
  • Thanks to blessed for building the interactive terminal UI.
  • Thanks to termcolor for colored terminal output.
  • Thanks to Streamlit for providing the web dashboard framework.

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

nvidb-1.6.5.tar.gz (58.7 kB view details)

Uploaded Source

Built Distribution

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

nvidb-1.6.5-py3-none-any.whl (58.7 kB view details)

Uploaded Python 3

File details

Details for the file nvidb-1.6.5.tar.gz.

File metadata

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

File hashes

Hashes for nvidb-1.6.5.tar.gz
Algorithm Hash digest
SHA256 133f04d79236f9b04b044109ebab41b0db17e6d62d82f95d0b094ec93ec6c0b8
MD5 139a0f50a9e6870b038280fe2cdf13e8
BLAKE2b-256 19cee5ecd95ed584819bb4749297beca0b8243629b5e6d561d8fb294b0d948a7

See more details on using hashes here.

Provenance

The following attestation bundles were made for nvidb-1.6.5.tar.gz:

Publisher: python-publish.yml on FanBB2333/nvidb

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

File details

Details for the file nvidb-1.6.5-py3-none-any.whl.

File metadata

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

File hashes

Hashes for nvidb-1.6.5-py3-none-any.whl
Algorithm Hash digest
SHA256 c163c8474e4e6304c3e2f096dd5476439dd0d815910aad5837c289474b044890
MD5 9f2c686c07be9420b761afadb2a7b632
BLAKE2b-256 560bc3a405d30830da943a68bd3c82f7b59032a300c5e840d4fb57bc5248abd5

See more details on using hashes here.

Provenance

The following attestation bundles were made for nvidb-1.6.5-py3-none-any.whl:

Publisher: python-publish.yml on FanBB2333/nvidb

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