Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samuelcolvin/dnserver
Simple development DNS server written in python
https://github.com/samuelcolvin/dnserver
dns dns-server python python3 testing
Last synced: 8 days ago
JSON representation
Simple development DNS server written in python
- Host: GitHub
- URL: https://github.com/samuelcolvin/dnserver
- Owner: samuelcolvin
- License: mit
- Created: 2017-02-26T18:04:39.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2024-04-04T13:10:19.000Z (7 months ago)
- Last Synced: 2024-10-18T12:16:16.837Z (20 days ago)
- Topics: dns, dns-server, python, python3, testing
- Language: Python
- Homepage: https://pypi.org/project/dnserver/
- Size: 47.9 KB
- Stars: 153
- Watchers: 7
- Forks: 63
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# dnserver
[![CI](https://github.com/samuelcolvin/dnserver/workflows/CI/badge.svg?event=push)](https://github.com/samuelcolvin/dnserver/actions?query=event%3Apush+branch%3Amain+workflow%3ACI)
[![Coverage](https://codecov.io/gh/samuelcolvin/dnserver/branch/main/graph/badge.svg)](https://codecov.io/gh/samuelcolvin/dnserver)
[![pypi](https://img.shields.io/pypi/v/dnserver.svg)](https://pypi.python.org/pypi/dnserver)
[![docker](https://img.shields.io/docker/image-size/samuelcolvin/dnserver?sort=date)](https://hub.docker.com/r/samuelcolvin/dnserver/)
[![versions](https://img.shields.io/pypi/pyversions/dnserver.svg)](https://github.com/samuelcolvin/dnserver)
[![license](https://img.shields.io/github/license/samuelcolvin/dnserver.svg)](https://github.com/samuelcolvin/dnserver/blob/main/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`](https://www.cloudflare.com/learning/dns/what-is-1.1.1.1/).You can set up records you want to serve with a custom `zones.toml` file,
see [example_zones.toml](https://github.com/samuelcolvin/dnserver/blob/main/example_zones.toml) an example.## Installation from PyPI
Install with:
```bash
pip install dnserver
```Usage:
```bash
dnserver --help
```(or `python -m dnserver --help`)
For example, to serve a file called `my_zones.toml` file on port `5053`, run:
```bash
dnserver --port 5053 my_zones.toml
```## Usage with Python
```python
from dnserver import DNSServerserver = 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:
```bash
docker run -p 5053:53/udp -p 5053:53/tcp --rm samuelcolvin/dnserver
```(See [dnserver on hub.docker.com](https://hub.docker.com/r/samuelcolvin/dnserver/))
Or with a custom zone file:
```bash
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
```shell
~ ➤ 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.