Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rakheshster/docker-stubby-dnsmasq
Stubby+Dnsmasq Docker image for DNS-over-TLS and optionally DHCP
https://github.com/rakheshster/docker-stubby-dnsmasq
dhcp-server dns-over-tls dns-server dnsmasq docker-image nextdns s6-overlay stubby
Last synced: 3 months ago
JSON representation
Stubby+Dnsmasq Docker image for DNS-over-TLS and optionally DHCP
- Host: GitHub
- URL: https://github.com/rakheshster/docker-stubby-dnsmasq
- Owner: rakheshster
- License: mit
- Created: 2020-08-06T17:46:32.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-31T11:00:56.000Z (almost 2 years ago)
- Last Synced: 2024-02-14T21:50:08.479Z (12 months ago)
- Topics: dhcp-server, dns-over-tls, dns-server, dnsmasq, docker-image, nextdns, s6-overlay, stubby
- Language: Shell
- Homepage:
- Size: 85.9 KB
- Stars: 4
- Watchers: 2
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Stubby + Dnsmasq + Docker
![Buildx & Push to DockerHub](https://github.com/rakheshster/docker-stubby-dnsmasq/workflows/Docker%20Build%20&%20Push/badge.svg)## What is this?
This is a Docker image containing Stubby and Dnsmasq.From the [Stubby documentation](https://dnsprivacy.org/wiki/display/DP/DNS+Privacy+Daemon+-+Stubby):
> Stubby is an application that acts as a local DNS Privacy stub resolver (using DNS-over-TLS). Stubby encrypts DNS queries sent from a client machine (desktop or laptop) to a DNS Privacy resolver increasing end user privacy.As of version 0.3 Stubby also supports DNS-over-HTTPs. This Docker image contains version 0.3.
Dnsmasq is a lightweight and small footprint DHCP and DNS server. You can read more about it on its [documentation](http://www.thekelleys.org.uk/dnsmasq/doc.html) page. Dnsmasq can answer DNS queries from a local file as well as forward to an upstream server.
This Stubby + Dnsmasq Docker image packages the two together. It sets up Stubby listening on port 8053 with Dnsmasq listening on port 53 and forwarding to Stubby port 8053.
## Getting this
It is best to target a specific release when pulling this repo. Either switch to the correct tag after downloading, or download a zip of the latest release from the [Releases](https://github.com/rakheshster/docker-stubby-dnsmasq/releases) page.Version numbers are of the format `-` where `` will be increments due to changes introduced by me (maybe a change to the Dockerfile or underlying Alpine/ s6 base). I know I should target specific versions of Dnsmasq rather than let it follow whatever is in the Alpine repos. I got side tracked with other projects so didn't spend time sorting this out.
You can download this from Docker Hub as [rakheshster/stubby-dnsmasq:version](https://hub.docker.com/repository/docker/rakheshster/stubby-dnsmasq).
## s6-overlay
I also took the opportunity to setup an [s6-overlay](https://github.com/just-containers/s6-overlay). I like their philosophy of a Docker container being “one thing” rather than “one process per container”. This is why I chose to create one image for both Stubby & Docker instead of separate images. It was surprisingly easy to setup.The `etc` folder contains a `services.d` folder that holds the service definitions for Stubby and Dnsmasq. Dnsmasq is set to depend on Stubby via a `dependencies` file so they start in the correct order. The config files and service definitions are intentionally set to run Stubby and Dnsmasq in the foreground. That’s because s6 expects them to run in the foreground. Moreover, each service runs under a separate non-root user account.
## Configuring
The `root` folder has the following structure.```
root
├── etc
│ ├── dnsmasq
│ │ └── dnsmasq.conf
│ ├── dnsmasq.d
│ │ ├── dnsmasq.conf
│ │ ├── dnsmasq.conf.orig
│ │ └── README.txt
│ ├── services.d
│ │ ├── dnsmasq
│ │ │ ├── dependencies
│ │ │ └── run
│ │ └── stubby
│ │ └── run
│ └── stubby
│ ├── stubby.orig.yml
│ └── stubby.yml
└── usr
└── sbin
└── dnsmasq-reload
```### Dnsmasq
The `dnsmasq.d` folder is of interest if you want to tweak the Dnsmasq config or add zones etc. All it currently has is a README file and the original `dnsmasq.conf` zone file. Out of the box Dnsmasq is setup to answer DNS queries by forwarding to Stubby and does not offer DHCP or any additional DNS zones.When the image is built the contents of this folder are copied into it as `/etc/dnsmasq.d`, but during runtime a new docker volume and mapped to this location *within the container*. Since the new docker volume is empty upon creation, the first time the container is run the contents of `/etc/dnsmasq.d` are copied from the container to this volume. If you then make any changes to this folder from within the container it will be stored in the docker volume.
Dnsmasq is set to pull in any files ending with `*.conf` from this folder into the running config.
You can edit the file via `docker exec` like thus:
```
docker exec -it stubby-dnsmasq vi /etc/dnsmasq.d/somefile.conf
```Or you copy a file from outside the container to it:
```
docker cp somefile.conf stubby-dnsmasq:/etc/dnsmasq.d/
```After making changes reload unload so it pulls in this config. The `/usr/sbin/dnsmasq-reload` script does that. Run it thus:
```
docker exec stubby-dnsmasq dnsmasq-reload
```### Stubby
Stubby doesn't need any configuring but it would be a good idea to change the upstream DNS servers after downloading this repo and before building the image.When the image is built the `stubby` folder is copied into it as `/etc/stubby`, but during runtime a new docker volume is created and mapped to this location within the container (similar to what I do above). Since this volume is empty the first time, the contents of `/etc/stubby` are copied over to this docker volume but any subsequent changes its contents are stored in the docker volume.
You can edit the config file or copy from outside the container using similar commands as above.
## Building & Running
The quickest way to get started after cloning/ downloading this repo is to use the `./.scripts/buildlocal.sh` file. It takes the name and tag to assign the image from the `buildinfo.json` file.NOTE: the script is optional. You can build this via `docker build` too. And additional script `./.scripts/buildxandpush.sh` is what I use to create multi-arch images and push to Docker Hub. It too is optional.
After the image is built you can run it manually via `docker run` or you use the `./.scripts/createcontainer.sh` script which takes the image name and container name as mandatory parameters and optionally the IP address and network of the container. I tend to use a macvlan network to run this so the container has its own IP address on my network.
### Systemd integration
The `./.scripts/createcontainer.sh` script doesn’t run the container. It creates the container and also creates a systemd service unit file along with some instructions on what to do with it. This way you have systemd managing the container so it always starts after a system reboot. The unit file and systemd integration is optional of course; I wanted the container to always start after a reboot as it provides DNS for my home lab and is critical, that’s why I went through this extra effort.Note: The service unit file is set to only restart if the service is aborted. This is intentional in case you want to `docker stop` the container sometime.
## Notes
This was my second Docker image. It has changed substantially since the initial days as I learnt more from building other images and tried to keep things common across all my images. I have a similar [Stubby + Unbound](https://github.com/rakheshster/docker-stubby-unbound) image.While creating this Stubby + Dnsmasq image I spent some time setting up multistage builds and thinking about how to store data. Again, nothing fancy but all of this was a learning experience for me so I am quite pleased. These learnings are now incorporated in the [Stubby + Unbound](https://github.com/rakheshster/docker-stubby-unbound) image too.
As noted earlier I know I should target specific versions of Dnsmasq rather than let it follow whatever is in the Alpine repos. I got side tracked with other projects so didn't spend time sorting this out.