Skip to main content

Track and visualize GPU energy consumption using PyNVML, with MongoDB integration.

Project description

EnergyMonitor

Overview

EnergyMonitor is a Python-based tool that tracks GPU power consumption using NVIDIA Management Library (NVML) and stores energy usage data in a MongoDB database. It allows users to log in, track energy consumption per project, and store run-specific energy data.

Features

  • User Authentication: Secure login using bcrypt.
  • Energy Monitoring: Tracks GPU power usage using NVML.
  • Project-Based Tracking: Associates energy consumption data with different projects.
  • Database Storage: Saves energy consumption history in MongoDB.
  • Automatic Timing: Energy tracking automatically starts and stops when monitoring begins and ends.

Installation Requirements

Before using the tool, install the required dependencies:

pip install pymongo bcrypt pynvml

Ensure you have:

  • A MongoDB database (e.g., MongoDB Atlas or a local instance).
  • NVIDIA GPU and drivers installed.
  • NVML library (included in the NVIDIA drivers).

Usage

1. Import and Initialize

from energy_monitor import EnergyMonitor
monitor = EnergyMonitor()

2. Login

Before tracking energy consumption, log in with:

monitor.login("username", "password")

3. Start Monitoring

Start tracking energy consumption for a specific project:

monitor.start("ProjectName")
  • If the project does not exist, it prompts the user to create one.
  • The timer automatically starts when monitoring begins.

4. Stop Monitoring

To stop tracking and save energy data:

monitor.stop()
  • This automatically calculates the total energy used and duration.
  • Data is stored in the database.

Functions

login(username, password)

Inputs:

  • username (str): The username of the user.
  • password (str): The corresponding password.

Functionality:

  • Authenticates the user with a hashed password.
  • Stores the user ID after successful login.

start(project_name)

Inputs:

  • project_name (str): Name of the project to track energy usage.

Functionality:

  • Initializes GPU energy monitoring.
  • Checks if the project exists; if not, prompts user to create one.
  • Automatically starts the timer when monitoring begins.

stop()

Functionality:

  • Automatically stops the timer and calculates energy consumption.
  • Stores run details like duration, timestamp, and energy used.
  • Saves data in MongoDB.

Database Structure

Each user document in MongoDB follows this structure:

{
    "_id": ObjectId("..."),
    "username": "user123",
    "password": "hashed_password",
    "projects": {
        "ProjectName": {
            "run1": {
                "timestamp": "2025-03-08T12:00:00Z",
                "duration": 3600,
                "energy": 500000,
                "energy_kwh": 0.138
            }
        }
    }
}

Notes

  • Make sure you log in before starting monitoring.
  • Ensure your GPU supports NVML.
  • Timing is handled automatically; no need for manual tracking.

License

This project is open-source. Feel free to modify and extend it!

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

energycnv-1.0.23.tar.gz (4.8 kB view details)

Uploaded Source

Built Distribution

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

energycnv-1.0.23-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

Details for the file energycnv-1.0.23.tar.gz.

File metadata

  • Download URL: energycnv-1.0.23.tar.gz
  • Upload date:
  • Size: 4.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.11

File hashes

Hashes for energycnv-1.0.23.tar.gz
Algorithm Hash digest
SHA256 5bc67ae4b0bb82dadf8a3a5e545a6ae5dd5ef71cd6e7d5f80f4bfb450bf1c08e
MD5 641209aabdd171e9cacdd7d4700cd0be
BLAKE2b-256 14a9336b23817d02d4198f98d8630498dece68957d9a0ba885ceed159cf32c5e

See more details on using hashes here.

File details

Details for the file energycnv-1.0.23-py3-none-any.whl.

File metadata

  • Download URL: energycnv-1.0.23-py3-none-any.whl
  • Upload date:
  • Size: 5.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.11

File hashes

Hashes for energycnv-1.0.23-py3-none-any.whl
Algorithm Hash digest
SHA256 bb82dd8375ec1f489286d1deb85c4cb1b3a02e1030fc3ab0ac70594f3c2ce2b9
MD5 6fa9355f9a1855f380e449bc4c71432c
BLAKE2b-256 33c51848bac3a715de7bb4fde09f9b0ea53305382427795447d7ffa1b0ecef63

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