Tracarbon is a Python library that tracks your device's energy consumption and calculates your carbon emissions.
It detects your location and your device automatically before starting to export measurements to an exporter. It could be used as a CLI with already defined metrics or programmatically with the API by defining the metrics that you want to have.
Read more in this article.
# Install Tracarbon
pip install tracarbon# Install one or more exporters from the list
pip install 'tracarbon[datadog,prometheus,kubernetes]'| Devices | Description |
|---|---|
| Mac | โ
Global energy consumption of your Mac (must be plugged into a wall adapter). Supports Apple Silicon GPU power tracking via powermetrics (requires sudo). |
| Linux | โ
Supports Intel and AMD processors via RAPL. Intel uses the powercap interface. AMD is supported on kernel 5.8+ (powercap) or via the amd_energy driver (HWMON). Works with containers on Kubernetes using the Metric API if available. |
| Windows | โ Not yet implemented. See #184. |
| Cloud Provider | Description |
|---|---|
| AWS | โ Use the hardware's usage with the EC2 instances carbon emissions datasets of cloud-carbon-coefficients. |
| GCP | โ Use the hardware's usage with the GCP instances carbon emissions datasets of cloud-carbon-coefficients. |
| Azure | โ Use the hardware's usage with the Azure instances carbon emissions datasets of cloud-carbon-coefficients. |
| GPU | Description |
|---|---|
| NVIDIA | โ
Supported via nvidia-smi. Works on Linux, Windows, and Intel Macs. Supports multiple GPUs. |
| AMD | โ
Supported via rocm-smi or amd-smi on Linux. Supports multiple GPUs. |
| Apple Silicon | โ
Supported via powermetrics on Mac (requires sudo). Tracks integrated GPU power on M1/M2/M3/M4 chips. |
| Intel | โ Not yet implemented. |
| Exporter | Description |
|---|---|
| Stdout | Print the metrics in Stdout. |
| JSON | Write the metrics in a JSON file. |
| Prometheus | Send the metrics to Prometheus. |
| Datadog | Send the metrics to Datadog. |
| Location | Description | Source |
|---|---|---|
| Worldwide | Get the latest co2g/kwh in near real-time using the CO2Signal or ElectricityMaps APIs. See here for the list of available zones. | CO2Signal API or ElectricityMaps |
| Europe | Static file created from the European Environment Agency Emission for the co2g/kwh in European countries. | EEA website |
| AWS | Static file of the AWS Grid emissions factors. | cloud-carbon-coefficients |
| GCP | Static file of the GCP Grid emissions factors (2024 yearly data). | GoogleCloudPlatform/region-carbon-info |
| Azure | Static file of the Azure Grid emissions factors. | cloud-carbon-coefficients |
The environment variables can be set from an environment file .env.
| Parameter | Description |
|---|---|
| TRACARBON_CO2SIGNAL_API_KEY | The api key received from CO2Signal or ElectricityMaps. |
| TRACARBON_CO2SIGNAL_URL | The url of CO2Signal is the default endpoint to retrieve the last known state of the zone, but it could be changed to ElectricityMaps. |
| TRACARBON_METRIC_PREFIX_NAME | The prefix to use in all the metrics name. |
| TRACARBON_INTERVAL_IN_SECONDS | The interval in seconds to wait between the metrics evaluation. |
| TRACARBON_LOG_LEVEL | The level to use for displaying the logs. |
Request your API key
- Go to CO2Signal and get your free API key for non-commercial use, or go to ElectricityMaps for commercial use.
- This API is used to retrieve the last known carbon intensity (in gCO2eq/kWh) of electricity consumed in your location.
- Set your API key in the environment variables, in the
.envfile or directly in the configuration. - If you would like to start without an API key, it's possible, the carbon intensity will be loaded statistically from a file.
- Launch Tracarbon ๐
Command Line
tracarbon runAPI
from tracarbon import TracarbonBuilder, TracarbonConfiguration
configuration = TracarbonConfiguration() # Your configuration
tracarbon = TracarbonBuilder(configuration=configuration).build()
tracarbon.start()
# Your code
tracarbon.stop()
with tracarbon:
# Your code
report = tracarbon.report() # Get the reportLocal: using uv
make init
make test-unitThe documentation is hosted here: https://fvaleye.github.io/tracarbon/documentation
