From 97d5748664afaa0e9bb6e62458428b826c79ccf9 Mon Sep 17 00:00:00 2001 From: Olga Traczyk Date: Mon, 15 Nov 2021 18:42:13 +0100 Subject: [PATCH] Add support for uppercase PROMETHEUS_MULTIPROC_DIR (#276) The variable name prometheus_multiproc_dir was deprecated in django-prometheus 0.10.0 in favor of PROMETHEUS_MULTIPROC_DIR. --- django_prometheus/exports.py | 3 ++- documentation/exports.md | 8 ++++---- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/django_prometheus/exports.py b/django_prometheus/exports.py index 6f68674a..3acd2660 100644 --- a/django_prometheus/exports.py +++ b/django_prometheus/exports.py @@ -115,7 +115,8 @@ def ExportToDjangoView(request): You can use django_prometheus.urls to map /metrics to this view. """ - if "prometheus_multiproc_dir" in os.environ: + if ("PROMETHEUS_MULTIPROC_DIR" in os.environ + or "prometheus_multiproc_dir" in os.environ): registry = prometheus_client.CollectorRegistry() multiprocess.MultiProcessCollector(registry) else: diff --git a/documentation/exports.md b/documentation/exports.md index d1b12bfd..b66d3716 100644 --- a/documentation/exports.md +++ b/documentation/exports.md @@ -78,22 +78,22 @@ targets as you have workers, using each port separately. This approach requires the application to be loaded into each child process. uWSGI and Gunicorn typically load the application into the master process before forking the child processes. -Set the [lazy-apps option](https://uwsgi-docs.readthedocs.io/en/latest/Options.html#lazy-apps) to `true` (uWSGI) +Set the [lazy-apps option](https://uwsgi-docs.readthedocs.io/en/latest/Options.html#lazy-apps) to `true` (uWSGI) or the [preload-app option](https://docs.gunicorn.org/en/stable/settings.html#preload-app) to `false` (Gunicorn) -to change this behaviour. +to change this behaviour. ## Exporting /metrics in a WSGI application with multiple processes globally In some WSGI applications, workers are short lived (less than a minute), so some are never scraped by prometheus by default. Prometheus client already provides -a nice system to aggregate them using the env variable: `prometheus_multiproc_dir` +a nice system to aggregate them using the env variable: `PROMETHEUS_MULTIPROC_DIR` which will configure the directory where metrics will be stored as files per process. Configuration in uwsgi would look like: ```ini -env = prometheus_multiproc_dir=/path/to/django_metrics +env = PROMETHEUS_MULTIPROC_DIR=/path/to/django_metrics ``` You can also set this environment variable elsewhere such as in a kubernetes manifest.