No project description provided
Project description
prometheus-dirsize-exporter
Export directory size metrics efficiently.
Why?
When providing multi-user interactive computing services (with a HPC cluster
or with JupyterHub), it's very helpful to know the home directory sizes of
each user over time. However, as NFS is often used, running du
constantly
takes a long time, uses too many IOPS that we may not have many of, and is
plain inefficient.
This project provides a way to keep track of directory sizes with a budgeted amount of IOPS. You can ask it to take however much time it needs but not use more than 100 IOPS, and it will do that. We do not necessarily need very up to date directory size metrics, so this is ok.
Limitations
- As directory contents might change in the course of a single run as we wait for budgets to become available, information about a directory may not be exactly correct immediately.
- Because we do not spread the IOPS through time, the IO usage is 'spiky' - all IOPS get done at the beginning of a second, and then it goes silent. If you have a big IOPS budget, this can cause performance degradation.
Installation
Install the package from PyPI:
pip install prometheus-dirsize-exporter
Running
You can start the process from the commandline:
dirsize-exporter <path-to-parent-directory> <iops-budget> <wait-time-in-minutes>
For example, to export metrics about directories under /home
, using no more
than 200 IO operations per second, updating every 60minutes, you would run:
dirsize-exporter /home 200 60
You can check out the metrics by hitting http://localhost:8000
. The port can
be controlled via a --port
argument.
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
Built Distribution
Hashes for prometheus-dirsize-exporter-1.1.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3769a30ab542a1fcdc4bbe1dea2a8849df0d47211cde8e7b818e2a0c6ff39327 |
|
MD5 | 371433c76e4601ea60e5e4c8f8536b27 |
|
BLAKE2b-256 | cb3e2722f667b47814206924747fa26bb5d6d91f6f1d9f2af1c2ef3f7564106a |
Hashes for prometheus_dirsize_exporter-1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d642afda1d8f0260abe7721a243d17238656179cc4e3f9662290842c2370b90d |
|
MD5 | 567d148ce41677e57cbb69bf99ada288 |
|
BLAKE2b-256 | 60628c64288b7377013973e0f799844f093c1cbb02f8e4f5d10ceb843b5a97af |