selfhosted-apps-docker/ddclient
DoTheEvolution dca41b0629 update
2020-05-22 00:06:39 +02:00
..
readme.md update 2020-05-22 00:06:39 +02:00

DDclient

guide-by-example

Purpose & Overview

Automatic DNS entries update.

DDclient is a Perl client used to update dynamic DNS records.
Very useful if not having a static IP from the ISP. It makes sure that if you reset your router, or have a power outage, and you get a new public IP assigned, this IP gets automaticly set in the DNS records for your domains.

This setup runs directly on the host machine.
It works by checking every 10 minutes checkip.dyndns.org, and if the IP changed from the previous one, it logs in to the DNS provider and updates the DNS records.

Files and directory structure

/etc/
└── ddclient/
    └── ddclient.conf

Installation

Install ddclient from your linux official repos.

Configuration

Official ddclient config example here.

This setup assumes the DNS records are managed on Cloudflare.
Make sure all subdomains in the config have A-records.

ddclient.conf

daemon=600
syslog=yes
mail=root
mail-failure=root
pid=/var/run/ddclient.pid
ssl=yes

use=web, web=checkip.dyndns.org/, web-skip='IP Address'

##
## CloudFlare (www.cloudflare.com)
##
protocol=cloudflare,        \
zone=example.com,              \
ttl=1,                      \
login=bastard@gmail.com, \
password=<global-api-key-goes-here> \
example.com,*.example.com,subdomain.example.com

##
protocol=cloudflare,        \
zone=example.org,              \
ttl=1,                      \
login=bastard@gmail.com, \
password=<global-api-key-goes-here> \
example.org,*.example.org,whatever.example.org

Start the service

sudo systemctl enable --now ddclient

Troubleshooting

If it would timeout on start, check the real location of ddclient.pid
sudo find / -name ddclient.pid

If it is correctly set in the ddclient.conf.

Update

During host linux packages update.

Backup and restore

Backup

Using borg that makes daily snapshot of the /etc directory which contains the config file.

restore

Replace the content of the config file with the one from the backup.