Dynamic DNS using DigitalOcean's DNS Services
Find a file
Tine Jozelj ae1afb952f
All checks were successful
ci / docker (push) Successful in 24s
feat: ipv6 support added
2023-07-18 13:43:22 +02:00
.github/workflows ci: remove github domain 2023-07-18 12:17:45 +02:00
Dockerfile Update Dockerfile 2020-12-14 12:57:34 +03:00
dyndns.sh feat: ipv6 support added 2023-07-18 13:43:22 +02:00
README.md docs: fix image name 2023-07-18 13:26:42 +02:00

Dynamic DNS using DigitalOcean's DNS Services

A script that pushes the public IP address of the running machine to DigitalOcean's DNS API's. It requires an existing A record to update. The resulting container image is roughly around 7 MB (thanks to Alpine Linux).

Setup

Assuming you already have a DigitalOcean account and your domain associated with it. Just add an A record with desired name and IP address. That's it!

Usage

Pick one of the options below using the following settings:

  • DIGITALOCEAN_TOKEN: The token you generate in DigitalOcean's API settings.
  • DOMAIN: The domain your subdomain is registered at. (i.e. foo.com for home.foo.com)
  • NAME: Subdomain to use. (name in A record) (i.e. home for home.foo.com). Multiple subdomains must be separated by semicolons ;
  • SLEEP_INTERVAL: Polling time in seconds. (default: 300)
  • REMOVE_DUPLICATES: If set to "true", removes extra DNS records if more than one A record is found on a subdomain. Note that if this is not enabled, the script will NOT update subdomains with more than one A record (default: false)
$ docker pull code.tjo.space/mentos1386/digitalocean-dyndns:main
$ docker run -d --name dyndns \
    -e DIGITALOCEAN_TOKEN="your_token_here" \
    -e DOMAIN="yourdomain.com" \
    -e NAME="subdomain" \
    -e SLEEP_INTERVAL=2 \
    -e REMOVE_DUPLICATES="true" \
    code.tjo.space/mentos1386/digitalocean-dyndns:main

Manual

You can also create a cronjob using below command:

$ DIGITALOCEAN_TOKEN="your_token_here" DOMAIN="yourdomain.com" NAME="subdomain" SLEEP_INTERVAL=2 ./dyndns.sh