DockDNS is a DNS updater, which supports configuring DNS records through Docker labels. Currently DockDNS only supports Cloudflare as a DNS provider.
- Dynamic DNS updates
- Static DNS entries (e.g. with a static IP address)
- Static DNS record configuration based on a config file
- Dynamic DNS record configuration based on Docker labels
- IPv4 & IPv6 support
- CNAME support
- Supports multiple zones
- Automatically trigger DNS updates when labeled containers start & stop
The app configuration as well as the static domain entries are read from a configuration file (see example configuration).
interval: 600 # Optional, the update interval in seconds. Defaults to 600. Negative interval will result in one-shot invocations.
debounceTime: 10 # Optional, delay the DNS update run until no new trigger event has been received for <<debounceTime>> seconds. This is used to avoid multiple DNS update runs when multiple containers are started/stopped in succession, e.g. by Docker Compose. Defaults to 10.
maxDebounceTime: 600 # Optional, if debouncing exceeds <<maxDebounceTime>> seconds, do not delay the DNS update beyond that. This avoids delaying the DNS update forever, e.g. in case of crash-looping containers that generate trigger events indefinitely. Defaults to 600.
webUI: false # Optional, enables a WebUI (port 8080) that lists the scanned domains and current settings. Defaults to false
log:
level: info # Optional, Log level, one of 'debug', 'info', 'warn' or 'error'. Defaults to 'info'
format: simple # Optional, output of the log format, 'simple' or 'json'. Defaults to 'simple'
zones: # Zone configuration (multiple zones can be provided)
- name: somedomain.com # Root name of the zone
provider: cloudflare # Name of the provider. Currently only Cloudflare is supported
apiToken: ... # API Token, needs permission 'Zone.Zone' (read) and Zone.DNS (edit)
zoneID: ... # ZoneID of this zone
dns:
a: true # Update IPv4 addresses
aaaa: false # Update IPv6 addresses
defaultTTL: 300 # Optional, default TTL for all records. Defaults to 300
purgeUnknown: true # Optional, delete unknown records. Defaults to false.
# Static domain configuration (optional)
domains:
- name: "*.somedomain.com" # IPs for A and AAAA records will be determined dynamically
comment: "Some comment" # Record comment
- name: "somedomain.com"
a: 10.0.0.2 # Static IPv4 address
aaaa: ::1 # Static IPv6 address
- name: "alt.somedomain.com" # Name of the CNAME record
cname: "main.somedomain.com" # Target of the CNAME record
Domains can also be configured using Docker labels. Supported labels:
Label | Example |
---|---|
dockdns.name | dockdns.name=somedomain.com |
dockdns.a | dockdns.a=127.0.0.1 |
dockdns.aaaa | dockdns.aaaa=::1 |
dockdns.cname | dockdns.cname=target.otherdomain.com |
dockdns.ttl | dockdns.ttl=600 |
dockdns.proxied | dockdns.proxied=false |
dockdns.comment | dockdns.comment=Some comment |
If no explicit IP address is set, the public IP will be fetched and set automatically (DynDNS).
If a CNAME
is set, A
and AAAA
settings are ignored.
go install github.com/Tarow/dockdns@latest
By default, DockDNS looks for a config.yaml
in the current folder. The location of the configuration file can be overwritten using the -config
flag:
dockdns -config /path/to/config.yaml
docker run -v ./config.yaml:/app/config.yaml -v /var/run/docker.sock:/var/run/docker.sock:ro ghcr.io/tarow/dockdns:latest
services:
dockdns:
image: ghcr.io/tarow/dockdns:latest
restart: unless-stopped
volumes:
- ./config.yaml:/app/config.yaml
- /var/run/docker.sock:/var/run/docker.sock:ro