Setup a custom dynamic DNS for instances in an OpenStack cloud
==========
The “ddns” set of scripts allow one to create a dynamic DNS for OpenStack cloud instances. Cloud providers may default to using unique and long hostnames, like instance.ff0f61549f3c4c6cb72a64f16572a524.compute.subdomain.domain.com.
One might prefer to use easier to remember hostnames, like instance.subdomain.domain.com. The “ddns” set of scripts allows one to use simpler hostnames. A cloud admin can use these scripts to to set up a hostname scheme and dynamic DNS for users in an OpenStack cloud.
This solution includes the following:
-
setup file - setup_ddns.sh
-
configuration file - ddns_config.yaml
-
ddns.sh executable - this main script will be autogenerated by setup_ddns.sh
-
python routines that are executed by scripts: ddns.py, gen_bind_files.py, gen_ddns_sh.py and ddns_common.py
-
templates directory, including templates for generating the following: ddns.sh, named.conf, forward and reverse zone files
-
Deploy a Ubuntu 18.04 instance for the DNS. It should be sufficient to choose a smaller flavor like “n1.small”.
-
Add a Floating IP (optional)
-
Setup security group rules for the DNS instance. The following ports should be open: TCP 22 (SSH), TCP 53 and UDP 53 (for DNS).
-
If the iptables service is on, it may be easiest to turn it off
-
Ensure that the OpenStack CLI clients are installed
Install the bind and bind-utils packages if they have not already been installed. Note that bind sets up the DNS server and bind-utils has the nsupdate tools.
ubuntu@ddns:~$ sudo apt update && sudo apt -y upgrade
ubuntu@ddns:~$ sudo apt install python-openstackclient python-yaml python-netaddr
ubuntu@ddns:~$ sudo apt install -y bind9
Using the Admin’s credentials will allow the “DDNS “ scripts to see instances across projects. If openrc.sh prompts for a password, remove the prompt and add the password in the file. Including the password in the file will be required for the scripts to run automatically. Below is an example of how to test the openrc.sh file using the OpenStack CLI.
ubuntu@ddns:~$ source openrc.sh
ubuntu@ddns:~$ openstack server list
For example,
ubuntu@ddns:~$ unzip /tmp/ddns.zip
The “ddns_config_sample.yaml” file has all of the configuration parameters that will be used to configure BIND and the “DDNS” scripts. Copy this file to “ddns_config.yaml” and input customized information. Then save the file. It is important to make sure there are no errors, like no overlapping IP ranges in this file. Note that all fields can take only one value with the exception of “forwarders” and “ip_ranges”. Multiple forwarders and IP address ranges can be included. The IP address ranges are for both the fixed and floating OpenStack networks. These scripts require that the ranges be on octet boundaries, e.g. /24, /16 or /8. Here is an already filled in sample of the required fields.
domain_name: cloud.myuniverse.org
dns_shortname: bigbang
dns_fixed_ip: 10.130.52.121
dns_floating_ip: 10.130.56.248
forwarders:
- 10.130.0.1
ip_ranges:
- 10.130.52.0/24
setup_ddns.sh creates configuration files for the DNS updates as well as configuration files for BIND. It then moves the BIND files to the appropriate directories and restarts the DNS (“named”) service. Feel free to view the script to see what it does. Run this script using “sudo”.
ubuntu@ddns:~$ sudo ./setup_ddns.sh
Now the main executable script, ddns.sh, has been created. It will use the OpenStack APIs to query instances and then update the DNS appropriately. Run the script.
ubuntu@ddns:~$ ./ddns.sh
The following example shows how to setup cron to call ddns.sh every minute.
ubuntu@ddns:~$ crontab –e
Once in the file, add “ * * * * * ”. To monitor if the cron is working monitor /var/log/messages with “tail –f /var/log/messages”.
###8. Test the DNS Server
Use ping and dig or nslookup to test the DNS server
An instance needs to be configured to resolve using the new DNS. Use cloud-config or configure the neutron dhcp server to provide with the right parameters.