Original forked from pboehm/ddns
A self-hosted Dynamic DNS solution similar to DynDNS or NO-IP based on the PowerDNS Remote Backend.
The hosted ddns service available at noip.at is powered by this repository.
You are welcome to try it out and use it in production.
noip.at — proudly operated by adminForge.de
ddns is built around a small webservice, so that you can update your IP address simply by calling
an URL periodically through curl. Hosts that haven't been updated for 90 days will
be automatically removed. This can be configured in your own instance.
An API similar to DynDNS/NO-IP has not been implemented yet.
- A custom domain where the registrar allows setting
NSrecords for subdomains. This is important because not all DNS providers support this. - A server with docker and docker-compose installed
- The following ports should be opened in the firewall:
53/udp80/tcp443/tcp
For the domain you want to use with ddns (example.net in the following sections, please adjust this to your domain)
you have to create the following two DNS records:
ddns.example.netas aCNAMEorA/AAAArecord pointing to the serverddnswill be running on. This record will be used for accessing theddnsfrontend in your browser or viacurl. It is also the target for the correspondingNSrecord.d.example.netas anNSrecord pointing to the previously createdddns.example.netrecord. This will delegate all subdomains underd.example.netto the PowerDNS server running onddns.example.net.
The setup is now automated using docker-compose and only some customization has
to be made in a docker-compose.override.yml file
(a sample is available here).
The setup included in this repository contains all the components described above and uses caddy as a web server, because it provides automatic HTTPS using Lets Encrypt.
git clone https://github.com/adminforge/ddns.git
cd ddns
cp docker-compose.override.yml.sample docker-compose.override.yml
Please adjust the settings in docker-compose.override.yml marked with the #<<< .... comments as follows:
- adjust the domain part in lines marked with
# <<< ADJUST DOMAINaccording to your DNS-Setup - insert your email address in lines marked with
# <<< INSERT EMAILwhich is required for getting certificates from Lets Encrypt
Finally execute the following docker-compose command, which creates 4 containers in detached mode which are also
started automatically after reboot. For updating an existing installation use the same command because it automatically
rebuilds the containers.
docker compose up -d --build
... for further customization
| Service | Variable | Default | Required | Description |
|---|---|---|---|---|
| ddns | DDNS_DOMAIN | d.example.net | yes | DDNS Domain and Zone-Root-Domain |
| ddns | DDNS_SOA_DOMAIN | ddns.example.net | yes | NS Server and Domain for Frontend |
| ddns | DDNS_EXPIRATION_DAYS | 90 | no | Days how long the dynamic DNS Record is valid |
| ddns | DDNS_TTL | 300 | no | TTL of the DNS Records |
| powerdns | PDNS_CARBON_SERVER | empty | no | Endpoint for collecting PDNS Metrics |
| powerdns | PDNS_CARBON_OURNAME | empty | no | Name of this Server for Metric collection |
| powerdns | PDNS_ZONE_CACHE | true | no | Zone-Cache Feature in PDNS refuses any requests whihc do not belong to configured Zone. Recommended to leave this on to increase security and the integrity of the DNS responses. |
There are serveral areas of the frontend that can be customized. The Customization is split into three parts:
- Favicon and Logo in the header
- Colors in the frontend through CSS Variables
- Title, Slogan and Footer through custom templates
Thening is done in the folder /theme and can be customized by editing resp. adding the files in this folder.
- For logo and favicon use
logo.pngandfavicon.ico. Simply place these files in the/themefolder. - For Coluring change the eg. primary variable in
theme.scss. You might want to add additional boostrap features, but don't remove the existing ones. Otherwise the frontend will break. - For Title, Slogan and Footer use the
sample.custom.tmplfile and rename it tocustom.tmpl. With changing the content of the templates, you can customize the frontend as you like.
