|
1 | 1 | from django.apps import AppConfig
|
2 | 2 |
|
| 3 | +from .queues import filter_connection_params, get_connection, get_queue_class, get_unique_connection_configs |
| 4 | +from .workers import get_worker_class |
| 5 | + |
| 6 | +import logging |
| 7 | + |
| 8 | +log = logging.getLogger(__name__) |
| 9 | + |
| 10 | +try: |
| 11 | + import prometheus_client |
| 12 | + |
| 13 | + from rq_exporter.collector import RQCollector |
| 14 | +except ImportError: |
| 15 | + RQCollector = None |
| 16 | + |
3 | 17 |
|
4 | 18 | class DjangoRqAdminConfig(AppConfig):
|
5 | 19 | default_auto_field = "django.db.models.AutoField"
|
6 | 20 | name = "django_rq"
|
| 21 | + |
| 22 | + def ready(self): |
| 23 | + if RQCollector is None: |
| 24 | + return |
| 25 | + |
| 26 | + from .settings import QUEUES |
| 27 | + |
| 28 | + worker_class = get_worker_class() |
| 29 | + collector_args = {} |
| 30 | + collector_counts = {} |
| 31 | + unique_configs = get_unique_connection_configs() |
| 32 | + for name, config in QUEUES.items(): |
| 33 | + index = unique_configs.index(filter_connection_params(config)) |
| 34 | + queue_class = get_queue_class(config) |
| 35 | + key = index, queue_class |
| 36 | + if key not in collector_args: |
| 37 | + collector_args[key] = [name, worker_class, queue_class] |
| 38 | + collector_counts[key] = 1 |
| 39 | + else: |
| 40 | + collector_counts[key] += 1 |
| 41 | + |
| 42 | + if len(collector_args) > 1: |
| 43 | + log.warning('RQCollector can only log metrics for one unique connection and queue class') |
| 44 | + |
| 45 | + if collector_args: |
| 46 | + key = sorted(collector_counts.items(), key=lambda x: x[1], reverse=True)[0][0] |
| 47 | + name, worker_class, queue_class = collector_args[key] |
| 48 | + prometheus_client.REGISTRY.register(RQCollector(get_connection(name), worker_class, queue_class)) |
0 commit comments