Skip to main content

Simple DNS server written in python for use in development and testing.

Project description

dnserver

CI Coverage pypi docker versions license

Simple DNS server written in python for use in development and testing.

The DNS serves its own records, if none are found it proxies the request to an upstream DNS server eg. CloudFlare at 1.1.1.1.

You can set up records you want to serve with a custom zones.toml file, see example_zones.toml an example.

Installation from PyPI

Install with:

pip install dnserver

Usage:

dnserver --help

(or python -m dnserver --help)

For example, to serve a file called my_zones.toml file on port 5053, run:

dnserver --port 5053 my_zones.toml

Usage with Python

from dnserver import DNSServer

server = DNSServer.from_toml('example_zones.toml', port=5053)
server.start()
assert server.is_running

# now you can do some requests with your favorite dns library

server.stop()

Usage with Docker

To use with docker:

docker run -p 5053:53/udp -p 5053:53/tcp --rm samuelcolvin/dnserver

(See dnserver on hub.docker.com)

Or with a custom zone file:

docker run -p 5053:53/udp -v `pwd`/zones.toml:/zones/zones.toml --rm samuelcolvin/dnserver

(assuming you have your zone records at ./zones.toml, TCP isn't required to use dig, hence why it's omitted in this case.)

You can then test (either of the above) with

~   dig @localhost -p 5053 example.com MX
...
;; ANSWER SECTION:
example.com.		300	IN	MX	5 whatever.com.
example.com.		300	IN	MX	10 mx2.whatever.com.
example.com.		300	IN	MX	20 mx3.whatever.com.

;; Query time: 2 msec
;; SERVER: 127.0.0.1#5053(127.0.0.1)
;; WHEN: Sun Feb 26 18:14:52 GMT 2017
;; MSG SIZE  rcvd: 94

~   dig @localhost -p 5053 tutorcruncher.com MX
...
;; ANSWER SECTION:
tutorcruncher.com.	299	IN	MX	10 aspmx2.googlemail.com.
tutorcruncher.com.	299	IN	MX	5 alt1.aspmx.l.google.com.
tutorcruncher.com.	299	IN	MX	5 alt2.aspmx.l.google.com.
tutorcruncher.com.	299	IN	MX	1 aspmx.l.google.com.
tutorcruncher.com.	299	IN	MX	10 aspmx3.googlemail.com.

;; Query time: 39 msec
;; SERVER: 127.0.0.1#5053(127.0.0.1)
;; WHEN: Sun Feb 26 18:14:48 GMT 2017
;; MSG SIZE  rcvd: 176

You can see that the first query took 2ms and returned results from example_zones.toml, the second query took 39ms as dnserver didn't have any records for the domain so had to proxy the query to the upstream DNS server.

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dnserver-0.4.0.tar.gz (13.4 kB view details)

Uploaded Source

Built Distribution

dnserver-0.4.0-py3-none-any.whl (8.6 kB view details)

Uploaded Python 3

File details

Details for the file dnserver-0.4.0.tar.gz.

File metadata

  • Download URL: dnserver-0.4.0.tar.gz
  • Upload date:
  • Size: 13.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for dnserver-0.4.0.tar.gz
Algorithm Hash digest
SHA256 bef5b7385c074be7b521628ead203bdd4511e335e8556953ccc59b41cbe10dca
MD5 5547689b8e4f08e6cd483519fdadcadf
BLAKE2b-256 d2bd998ed6dd94a1717c1ab2acdad385148f776246ea884ec16463d1011aa5cc

See more details on using hashes here.

File details

Details for the file dnserver-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: dnserver-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 8.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for dnserver-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cbed0833bb9e510bbbecb8a7d7ec6c51a807146f2e7d4448afac4cee5a0ca9eb
MD5 129784d7d2246cb64577323077b3b38f
BLAKE2b-256 840ffa73f02422ed83c5774ddf1dc6bb70edd444b8d66b3063550450cf5b5c7f

See more details on using hashes here.

Supported by

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