metrics.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. from prometheus_client import Counter, Histogram
  2. metrics = {}
  3. def get(name):
  4. return metrics.get(name)
  5. def set_counter(name, *args, **kwargs):
  6. metrics[name] = Counter(name, *args, **kwargs)
  7. def set_histogram(name, *args, **kwargs):
  8. metrics[name] = Histogram(name, *args, **kwargs)
  9. #models.py metrics
  10. set_counter('desecapi_captcha_content_created', 'number of times captcha content created', ['kind'])
  11. set_counter('desecapi_autodelegation_created', 'number of autodelegations added')
  12. set_counter('desecapi_autodelegation_deleted', 'number of autodelegations deleted')
  13. set_histogram('desecapi_messages_queued', 'number of emails queued', ['reason', 'user', 'lane'], buckets=[0, 1, float("inf")])
  14. #views.py metrics
  15. set_counter('desecapi_dynDNS12_domain_not_found', 'number of times dynDNS12 domain is not found')
  16. #crypto.py metrics
  17. set_counter('desecapi_key_encryption_success', 'number of times key encryption was successful', ['context'])
  18. set_counter('desecapi_key_decryption_success', 'number of times key decryption was successful', ['context'])
  19. #exception_handlers.py metrics
  20. set_counter('desecapi_database_unavailable', 'number of times database was unavailable')
  21. #pdns.py metrics
  22. set_counter('desecapi_pdns_request_success', 'number of times pdns request was successful', ['method', 'status'])
  23. set_counter('desecapi_pdns_keys_fetched', 'number of times pdns keys were fetched')
  24. #pdns_change_tracker.py metrics
  25. set_counter('desecapi_pdns_catalog_updated', 'number of times pdns catalog was updated successfully')
  26. #throttling.py metrics
  27. set_counter('desecapi_throttle_failure', 'number of requests throttled', ['method', 'scope', 'user'])
  28. #serializers.py metrics
  29. set_counter('desecapi_rrset_list_serializer', 'number of times RRsetListSerializer was initialized')