This is my setup for a dockerized DNS and DHCP server using the jpillora/dnsmasq docker image for dnsmasq.
I use this to set a local domain that points to my media server where I have a reverse proxy that points specific subdomains to the different services I have there. I also use it to block ads on my home network, using hosts.
The example conf reflects this setup but it can also be setup in any other way you'd want to use a DNS or DHCP server.
It uses the following ports:
- 8080 Web UI
- 53 DNS
- 67 DHCP
Currently this is running in "host" network mode, so it's not really as isolated as it could be, and there could be port conflicts. However this was the easiest option for getting the DHCP server to work in a docker container. Another option maybe using a macvlan network. This page contains a brief discussion of the different options.
Note that "bridge" mode works perfectly fine if all you need is a DNS server, and is preferable in that case. You also don't need NET_ADMIN capability if you're just running DNS.
- Clone this repo and cd into it
git clone https://github.com/PARC6502/docker-dns-dhcp.git && cd docker-dns-dhcp
- Make copies of example files
cp dnsmasq.example.conf dnsmasq.conf \
&& cp static_host.example static_hosts \
&& cp ad.example.list ad.list \
&& touch dnsmasq.log
-
Set a static IP for your server machine. You can either do this from the machine itself, setting an IP outside of the DHCP range, or from the
dnsmasq.conf
file -
Set the domain(s) and IP address(es) in the
dnsmasq.conf
file
This is the line you want to change
address=/.local.cloud/192.168.1.3
-
(Optional) You can set static IPs based on hostname or MAC address in
dnsmasq.conf
-
(Optional) Add static hosts to your static_hosts file (could point to different servers, android tv, etc)
-
(Optional) You can add sites you'd like to block in
ad.list
in the format shown below, I'm using this file on my network
0.0.0.0 facebook.com
-
Turn off DHCP in your router
For this container to work it's important that it's not clashing with another DHCP server. You need to access your router, find the DHCP option and turn it off. Take
-
Start up the container
sudo docker-compose up -d
You should be able to access the web UI at <IP address>:8080
, (user:foo, pass:bar).
You can view a live feed of the logs from the UI as well as make changes to dnsmasq.conf
. If you make changes to any of the files the dnsmasq will need to be restarted, this can be done from the UI or from the command line (note that you need to be in the folder with the docker-compose.yml
file for this command to work)
sudo docker-compose restart dnsmasq