Prometheus metrics for arq job queues
Project description
Arq-prometheus
Prometheus metrics for arq
⚠️ WARNING! This is a project in alpha phase ⚠️
Installation
pip install -U arq-prometheus
poetry add arq-prometheus
Description
The metrics exposed are the same as the health check.
| Metric name | Description |
|---|---|
arq_jobs_completed |
The number of jobs completed |
arq_jobs_failed |
The total number of errored jobs |
arq_jobs_retried |
The total number of retried jobs |
arq_ongoing_jobs |
The number of jobs in progress |
arq_queued_inprogress |
The number of jobs in progress |
When working with arq I found some limitations, it was specially hard to get access to
the worker in order to retrieve information like the queue_name or health_check_key.
The startup and shutdown functions only make available a ctx with the redis connection.
This means that if you provide a custom queue_name or health_check_key, you will
also have to provide them to ArqPrometheusMetrics.
Usage
# example_worker.py
from arq_prometheus import ArqPrometheusMetrics
async def startup(ctx):
arq_prometheus = ArqPrometheusMetrics(ctx, delay=delay)
ctx["arq_prometheus"] = await arq_prometheus.start()
async def shutdown(ctx):
await ctx["arq_prometheus"].stop()
class WorkerSettings:
on_startup = startup
on_shutdown = shutdown
function = [] # your arq jobs
... # other settings
Start your arq worker,
arq example_worker.WorkerSettings
Make request to localhost:8081 (or open in browser).
curl localhost:8081
Arguments
ctx: dict: arq contextqueue_name: str = default_queue_name: name of the arq queuehealth_check_key: Optional[str] = None: arq health keydelay: datetime.timedelta = datetime.timedelta(seconds=5): a datetime.timedeltaenable_webserver: bool = True: set to True if you want a web server exposing the metricsaddr: str = "0.0.0.0": webserver addressport: int = 8081: webserver portregistry: prom.CollectorRegistry = prom.REGISTRY: the prometheus registry, usually you do not have to override this
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file arq_prometheus-0.3.0.tar.gz.
File metadata
- Download URL: arq_prometheus-0.3.0.tar.gz
- Upload date:
- Size: 8.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.15.0-1035-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a4f21543150390170ffb484d9c959e92eb6977859fdf61d4afe8fbc0433954e
|
|
| MD5 |
6a815bad172eca2cf4edc9efd8c165a2
|
|
| BLAKE2b-256 |
ebf32a052bede18cfba7308bde19be21f9e4b002c8a97d2435127fb175d75450
|
File details
Details for the file arq_prometheus-0.3.0-py3-none-any.whl.
File metadata
- Download URL: arq_prometheus-0.3.0-py3-none-any.whl
- Upload date:
- Size: 9.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.15.0-1035-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ea19b1fe9d547a757e410496bed34f03f26a2c6c259c6ece76145d331ece80e3
|
|
| MD5 |
a17f2d2928f699dd383b8bfde077faef
|
|
| BLAKE2b-256 |
00a9376d34a65805b62b0467c45cbac4f0978cf8ee4ef5a4d2ba638042c3dcfc
|