Make DHCP inventory handling more flexible

Configure a hostsdir even when inventory_dhcp is false, so that
a deployment can use a mixed approach.

Stop creating an unused additional DNS hostsdir by default since
we disable DNS by default. While we're here, rename
disable_dnsmasq_dns -> ! dnsmasq_enable_dns for consistency.

Change-Id: If40f044a86cdde6d653bbfb441de53fb4071e390
This commit is contained in:
Dmitry Tantsur 2020-12-18 19:30:00 +01:00
parent aa727de74d
commit fc7d10a49b
4 changed files with 41 additions and 12 deletions

View File

@ -124,7 +124,6 @@ ipa_builder_git_url: https://opendev.org/openstack/ironic-python-agent-builder
prometheus_exporter_git_url: https://opendev.org/openstack/ironic-prometheus-exporter prometheus_exporter_git_url: https://opendev.org/openstack/ironic-prometheus-exporter
mysql_username: "root" mysql_username: "root"
mysql_password: "" mysql_password: ""
disable_dnsmasq_dns: True
ironic_git_folder: /opt/stack/ironic ironic_git_folder: /opt/stack/ironic
ironicclient_git_folder: /opt/stack/python-ironicclient ironicclient_git_folder: /opt/stack/python-ironicclient
openstacksdk_git_folder: /opt/stack/openstacksdk openstacksdk_git_folder: /opt/stack/openstacksdk
@ -164,6 +163,16 @@ dhcp_pool_start: 192.168.1.200
dhcp_pool_end: 192.168.1.250 dhcp_pool_end: 192.168.1.250
dhcp_lease_time: 12h dhcp_lease_time: 12h
dhcp_static_mask: 255.255.255.0 dhcp_static_mask: 255.255.255.0
# Whether to enable DNS in dnsmasq. Will conflict with any other DNS server,
# hence disabled by default.
dnsmasq_enable_dns: "{{ not (dnsmasq_disable_dns | default(True) | bool) }}"
# Directory with static DHCP hosts configuration.
dnsmasq_dhcp_hostsdir: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d"
# Uncomment to set up directory with additional hosts for DNS. Useless without
# dnsmasq_enable_dns set to True.
#dnsmasq_additional_hostsdir: "/etc/dnsmasq.d/bifrost.hosts.d"
# Dnsmasq default route for clients. If not defined, dnsmasq will push to clients # Dnsmasq default route for clients. If not defined, dnsmasq will push to clients
# as default route the same IP of the dnsmasq server. # as default route the same IP of the dnsmasq server.
# If set to false, it will disable default route creation in clients. # If set to false, it will disable default route creation in clients.

View File

@ -242,22 +242,23 @@
- name: "Create an ESP image" - name: "Create an ESP image"
import_tasks: create_esp.yml import_tasks: create_esp.yml
- name: "Setup Inventory Hosts Directory" - name: "Setup additional DHCP hosts directory"
file: file:
path: "/etc/dnsmasq.d/bifrost.hosts.d" path: "{{ dnsmasq_additional_hostsdir }}"
state: directory state: directory
owner: "root" owner: "root"
group: "root" group: "root"
mode: 0755 mode: 0755
when: inventory_dhcp | bool when: dnsmasq_additional_hostsdir is defined
- name: "Setup Inventory DHCP Hosts Directory"
- name: "Setup inventory DHCP hosts directory"
file: file:
path: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d" path: "{{ dnsmasq_dhcp_hostsdir }}"
state: directory state: directory
owner: "root" owner: "root"
group: "root" group: "root"
mode: 0755 mode: 0755
when: inventory_dhcp | bool
- name: "Retrieve interface IP informations" - name: "Retrieve interface IP informations"
set_fact: set_fact:
itf_infos: "{{ internal_interface }}" itf_infos: "{{ internal_interface }}"

View File

@ -7,10 +7,10 @@
# Listen on this specific port instead of the standard DNS port # Listen on this specific port instead of the standard DNS port
# (53). Setting this to zero completely disables DNS function, # (53). Setting this to zero completely disables DNS function,
# leaving only DHCP and/or TFTP. # leaving only DHCP and/or TFTP.
{% if disable_dnsmasq_dns | bool == true %} {% if dnsmasq_enable_dns | bool == true %}
port=0
{% else %}
port=53 port=53
{% else %}
port=0
{% endif %} {% endif %}
listen-address={{ internal_ip }} listen-address={{ internal_ip }}
@ -34,9 +34,13 @@ conf-dir=/etc/dnsmasq.d
# or if you want it to read another file, as well as /etc/hosts, use # or if you want it to read another file, as well as /etc/hosts, use
# this. # this.
#addn-hosts=/etc/banner_add_hosts #addn-hosts=/etc/banner_add_hosts
{% if dnsmasq_additional_hostsdir is defined %}
addn-hosts={{ dhcp_additional_hostsdir }}
{% endif %}
dhcp-hostsdir={{ dnsmasq_dhcp_hostsdir }}
{% if inventory_dhcp | bool == true %} {% if inventory_dhcp | bool == true %}
addn-hosts=/etc/dnsmasq.d/bifrost.hosts.d
dhcp-hostsfile=/etc/dnsmasq.d/bifrost.dhcp-hosts.d
dhcp-ignore=tag:!known dhcp-ignore=tag:!known
{% endif %} {% endif %}

View File

@ -0,0 +1,15 @@
---
features:
- |
The dynamic DHCP inventory hostsdir is now created and enabled by default,
even when ``inventory_dhcp`` is ``false``.
upgrade:
- |
An additional DNS hosts directory is no longer created by default in
``/etc/dnsmasq.d/bifrost.hosts.d`` when ``inventory_dhcp`` is ``true``.
Set the new variable ``dnsmasq_additional_hostsdir`` to keep the previous
behavior (you'll need ``dnsmasq_enable_dns=true`` to actually use it).
deprecations:
- |
The parameter ``disable_dnsmasq_dns`` has been deprecated in favor of
the new parameter ``dnsmasq_enable_dns``.