Automatically update a DNS A
record in Gandi LiveDNS whenever your computer's public IP address changes, detected automatically using a large, auto-updating pool of public STUN servers.
This is an alternative to filling out monthly CAPTCHAs for No-IP or paying for DynDNS, if you happen to already be paying for a domain name from the world's greatest domain registrar.
- .NET 8 Runtime or later
- Gandi domain name
- ✅ Domain must be using LiveDNS, the default for new domains (
ns-*-*.gandi.net
) - ❌ Classic DNS (
*.dns.gandi.net
) is incompatible; you will need to migrate to LiveDNS - ❌ External nameservers (with glue records) are incompatible; you will need to update the record on the external nameserver instead of on Gandi's nameservers
- ✅ Domain must be using LiveDNS, the default for new domains (
- Your computer must have a public WAN IPv4 address
- IPv6 is not supported because router NATs don't support IPv6 port forwarding, so an
AAAA
record wouldn't be useful
- IPv6 is not supported because router NATs don't support IPv6 port forwarding, so an
- Download the latest release ZIP archive for your operating system and CPU architecture
- Extract the ZIP archive to a directory, such as
C:\Program Files\GandiDynamicDns\
or/opt/gandidynamicdns/
- Extract
appsettings.json
during a new installation, but not when upgrading an existing installation
- Extract
- Install the service
- Windows:
& '.\Install service.ps1'
- Linux with systemd:
sudo cp gandidynamicdns.service /etc/systemd/system/ sudo systemctl daemon-reload sudo systemctl enable gandidynamicdns.service
- Windows:
Open appsettings.json
in a text editor and fill in the following values. Keys marked with ✴ are the most important ones to configure.
Key | Type | Examples | Description |
---|---|---|---|
gandiApiKey ✴ |
string |
abcdefg |
Generate an API key under Developer access in your Gandi Account. Does not accept Personal Access Tokens because they expire after a short duration and can't be refreshed, rendering them useless for headless service scenarios, and they're incompatible with the underlying third-party API client anyway. |
domain ✴ |
string |
example.com example.co.uk |
The second-level domain name that you registered, including the TLD. |
subdomain ✴ |
string |
www @ api.stage |
The subdomain whose DNS record you want to update, not including domain or a trailing period. To update domain itself, set this to @ (default). Can also be a multi-level subdomain. |
updateInterval |
TimeSpan |
0.00:05:00 |
How frequently this program will check if your public IP address has changed and update DNS. Format is d.hh:mm:ss . Defaults to 5 minutes.One-shot mode: if set to 0:0:0 or negative, this program will exit after the first update attempt, instead of remaining running and updating periodically; useful for custom triggers, like cron or systemd timers. |
dnsRecordTimeToLive |
TimeSpan |
0.00:05:00 |
How long DNS resolvers can cache your record before they must look it up again. Format is d.hh:mm:ss . Gandi requires this to be between 5 minutes and 30 days, inclusive. Defaults to 5 minutes. |
dryRun |
bool |
false true |
Set to false (default) to run normally, or true to avoid changing any DNS records. |
unanimity |
uint32 |
1 5 |
This many STUN servers must all agree on a new IP address in order to change the DNS record, otherwise it will be left unchanged. Defaults to 1 to only send a single request and use any valid public address, without confirming with other servers. |
stunServerBlacklist |
string[] |
["stun.bergophor.de", "stun.usfamily.net", "stun.finsterwalder.com"] |
List of STUN server hostnames to not use when determining your computer's public IP address. Defaults to blocking servers known to return incorrect responses. |
- Manually:
./GandiDynamicDns
- Windows service:
sc start GandiDynamicDns
, or useservices.msc
- Linux systemd service:
sudo systemctl start gandidynamicdns