Skip to main content

Multi-target Prometheus exporter with an exclusive focus on DNS monitoring

Project description

Run Tox CI Documentation Status Ruff codecov PyPI version Docker Image Version (latest semver)

dns_exporter

dns_exporter is a multi-target Prometheus exporter with an exclusive focus on DNS monitoring. It is built on the excellent libraries dnspython and the Prometheus Python client library.

dns_exporter can be used to monitor availability and performance of DNS servers, and to validate the responses they return. It can monitor recursive and authoritative servers regardless of the software they run. You can use it to make sure your (or your providers) DNS servers are sending the replies you expect and configure Prometheus and Alertmanager to notify you if something stops working.

dns_exporter works similar to the Blackbox exporter where Prometheus asks the exporter to scrape the target, rather than the exporter itself being the target. This is called the Multi Target Exporter Pattern. It is typically used in black-box style exporters where 1) the thing you are monitoring is not under your control, or 2) you want to measure the path as well. Often when monitoring DNS both 1) and 2) are relevant.

This means that for each scrape Prometheus speaks HTTP to the dns_exporter which then speaks DNS with the target DNS server and returns the resulting metrics over HTTP to Prometheus. dns_exporter supports doing DNS queries over plain port 53 UDP and TCP, as well as DoT, DoH, DoH3, and DoQ.

Installation

dns_exporter is not yet in any OS package managers but installing dns_exporter can be done from pypi. This is the recommended way to install for now:

pip install dns_exporter

There is also a Docker image so you can get your container on:

docker run -p 15353:15353 tykling/dns_exporter:latest

There is also a Kubernetes Helm Chart (maintained by @christianhuth) available on ArtifactHUB.

Python Support

Python 3.10, 3.11, 3.12, 3.13 and 3.14 are fully supported. dns_exporter aims to follow the officially supported Python versions.

Documentation

The documentation is available on ReadTheDocs

Grafana Dashboard

There is a Grafana dashboard you can use as a starting point for your own dashboards.

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

dns_exporter-1.2.3.tar.gz (76.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dns_exporter-1.2.3-py3-none-any.whl (39.4 kB view details)

Uploaded Python 3

File details

Details for the file dns_exporter-1.2.3.tar.gz.

File metadata

  • Download URL: dns_exporter-1.2.3.tar.gz
  • Upload date:
  • Size: 76.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dns_exporter-1.2.3.tar.gz
Algorithm Hash digest
SHA256 25e7b1f16ab938e8e4695ccfbdf4fc6e3f3ed527336aade8949718535870fc96
MD5 f3221a903a9b264130feda6419d95482
BLAKE2b-256 41e6f9eb679a8905e77325deead856344cf51e333f4b3b7d7a65cf0fa5108c6a

See more details on using hashes here.

Provenance

The following attestation bundles were made for dns_exporter-1.2.3.tar.gz:

Publisher: pypi.yml on tykling/dns_exporter

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dns_exporter-1.2.3-py3-none-any.whl.

File metadata

  • Download URL: dns_exporter-1.2.3-py3-none-any.whl
  • Upload date:
  • Size: 39.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dns_exporter-1.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 0966632cd64ac8a5973f70a52682c2b6b10440f11fd31c2c2db77cf2b8f909e7
MD5 8d1dcc711b75a9b5f8f0e2e9cf6e1c33
BLAKE2b-256 b59ecc2be4ce3d5679fd3c773e73f65c1d88e538cda04b73ed3bfd8ff7a5c435

See more details on using hashes here.

Provenance

The following attestation bundles were made for dns_exporter-1.2.3-py3-none-any.whl:

Publisher: pypi.yml on tykling/dns_exporter

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page