matrix-docker-ansible-deploy/docs/configuring-playbook-dynamic-dns.md
2025-04-04 10:14:40 +03:00

3.5 KiB
Raw Blame History

Setting up Dynamic DNS (optional)

The playbook can configure Dynamic DNS with ddclient for you. It is a Perl client used to update dynamic DNS entries for accounts on Dynamic DNS Network Service Provider.

Most cloud providers / ISPs will charge you extra for a static IP address. If you're not hosting a highly reliable homeserver you can workaround this via dynamic DNS.

Prerequisite

You'll need to authenticate with your DNS provider somehow, in most cases this is simply a username and password but can differ from provider to provider. Please consult with your providers documentation and the upstream ddclient documentation to determine what you'll need to provide to authenticate.

Adjusting the playbook configuration

To enable dynamic DNS, add the following configuration to your inventory/host_vars/matrix.example.com/vars.yml file:

matrix_dynamic_dns_enabled: true

matrix_dynamic_dns_domain_configurations:
  - provider: example.net
    protocol: dyndn2
    username: YOUR_USERNAME_HERE
    password: YOUR_PASSWORD_HERE
    domain: "{{ matrix_domain }}"

Keep in mind that certain providers may require a different configuration of the matrix_dynamic_dns_domain_configurations variable, for provider specific examples see the upstream documentation.

Extending the configuration

There are some additional things you may wish to configure about the component.

Take a look at:

  • roles/custom/matrix-dynamic-dns/defaults/main.yml for some variables that you can customize via your vars.yml file

Installing

After configuring the playbook, run it with playbook tags as below:

ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start

The shortcut commands with the just program are also available: just install-all or just setup-all

just install-all is useful for maintaining your setup quickly (2x-5x faster than just setup-all) when its components remain unchanged. If you adjust your vars.yml to remove other components, you'd need to run just setup-all, or these components will still remain installed. Note these shortcuts run the ensure-matrix-users-created tag too.

Additional Reading

Additional resources:

Troubleshooting

As with all other services, you can find the logs in systemd-journald by logging in to the server with SSH and running journalctl -fu matrix-dynamic-dns. However, due to an upstream issue the logging output is not always complete. For advanced debugging purposes running the ddclient tool outside of the container is useful via the following: ddclient -file ./ddclient.conf -daemon=0 -debug -verbose -noquiet.