Add dhcp related tasks to inspection role
In case when inventory_dhcp is enabled and node is not deployed yet, inspection is not working because dnsmasq ignores requests from unknown address. Change-Id: I048acc5093d186637db2e92915eb019dc3baab91
This commit is contained in:
parent
0128ca8638
commit
109cf98c03
@ -67,16 +67,16 @@ inventory_dhcp: A boolean value, defaulted to false, which allows dnsmasq
|
|||||||
parameter.
|
parameter.
|
||||||
|
|
||||||
inventory_dhcp_static_ip: A boolean value, defaulted to true, which configures
|
inventory_dhcp_static_ip: A boolean value, defaulted to true, which configures
|
||||||
the mechanism for setting up the IP of machines when
|
the mechanism for setting up the IP of machines when
|
||||||
inventory_dhcp is enabled.
|
inventory_dhcp is enabled.
|
||||||
If set to true, it will read the value of the key
|
If set to true, it will read the value of the key
|
||||||
'provisioning_ipv4_address' from the inventory section
|
'provisioning_ipv4_address' from the inventory section
|
||||||
of each machine and dnsmasq will assign that IP to each
|
of each machine and dnsmasq will assign that IP to each
|
||||||
machine accordingly. Note, that if you don't assign
|
machine accordingly. Note, that if you don't assign
|
||||||
the key 'provisioning_ipv4_address' it will default
|
the key 'provisioning_ipv4_address' it will default
|
||||||
to the value of 'ipv4_address'.
|
to the value of 'ipv4_address'.
|
||||||
If set to false, dnsmasq will assign IPs
|
If set to false, dnsmasq will assign IPs
|
||||||
automatically from the configured DHCP range.
|
automatically from the configured DHCP range.
|
||||||
|
|
||||||
noauth_mode: Controls if the module is called in noauth mode.
|
noauth_mode: Controls if the module is called in noauth mode.
|
||||||
By default, this is the standard mode of operation,
|
By default, this is the standard mode of operation,
|
||||||
@ -89,9 +89,9 @@ cloud_name: Optional: String value defining a clouds.yaml entry for
|
|||||||
the ansible module to leverage.
|
the ansible module to leverage.
|
||||||
|
|
||||||
inventory_dns: A boolean value, defaulted to false, which causes the role
|
inventory_dns: A boolean value, defaulted to false, which causes the role
|
||||||
to update a template file and reload dnsmasq upon each update
|
to update a template file and reload dnsmasq upon each update
|
||||||
in order to perform static dns addressing utilizing the
|
in order to perform static dns addressing utilizing the
|
||||||
ipv4_address parameter.
|
ipv4_address parameter.
|
||||||
|
|
||||||
Dependencies
|
Dependencies
|
||||||
------------
|
------------
|
||||||
|
@ -39,6 +39,33 @@ inspection_wait_timeout: Integer value in seconds, defaults to 1800.
|
|||||||
under 300 seconds, although that will vary based
|
under 300 seconds, although that will vary based
|
||||||
upon the hardware configuration.
|
upon the hardware configuration.
|
||||||
|
|
||||||
|
inventory_dhcp: A boolean value, defaulted to false, which allows dnsmasq
|
||||||
|
to configure the IP of the machines, rather than putting
|
||||||
|
the IP configuration of the machine in the config drive.
|
||||||
|
If set to true, the role will create a file for each machine
|
||||||
|
under /etc/dnsmasq.d/bifrost.dhcp-hosts.d containing the mac,
|
||||||
|
name of the machine, lease time and optionally the IP address
|
||||||
|
that will be offered to the machine by DHCP.
|
||||||
|
This optional IP is controlled by the inventory_dhcp_static_ip
|
||||||
|
parameter.
|
||||||
|
|
||||||
|
inventory_dhcp_static_ip: A boolean value, defaulted to true, which configures
|
||||||
|
the mechanism for setting up the IP of machines when
|
||||||
|
inventory_dhcp is enabled.
|
||||||
|
If set to true, it will read the value of the key
|
||||||
|
'provisioning_ipv4_address' from the inventory section
|
||||||
|
of each machine and dnsmasq will assign that IP to each
|
||||||
|
machine accordingly. Note, that if you don't assign
|
||||||
|
the key 'provisioning_ipv4_address' it will default
|
||||||
|
to the value of 'ipv4_address'.
|
||||||
|
If set to false, dnsmasq will assign IPs
|
||||||
|
automatically from the configured DHCP range.
|
||||||
|
|
||||||
|
inventory_dns: A boolean value, defaulted to false, which causes the role
|
||||||
|
to update a template file and reload dnsmasq upon each update
|
||||||
|
in order to perform static dns addressing utilizing the
|
||||||
|
ipv4_address parameter.
|
||||||
|
|
||||||
Dependencies
|
Dependencies
|
||||||
------------
|
------------
|
||||||
|
|
||||||
|
@ -2,3 +2,6 @@
|
|||||||
# defaults file for ironic-inspect-node
|
# defaults file for ironic-inspect-node
|
||||||
noauth_mode: true
|
noauth_mode: true
|
||||||
inspection_wait_timeout: 1800
|
inspection_wait_timeout: 1800
|
||||||
|
inventory_dhcp: false
|
||||||
|
inventory_dhcp_static_ip: true
|
||||||
|
inventory_dns: false
|
||||||
|
@ -32,6 +32,31 @@
|
|||||||
when: auth is undefined
|
when: auth is undefined
|
||||||
no_log: yes
|
no_log: yes
|
||||||
|
|
||||||
|
- name: "Setup DHCP for nodes."
|
||||||
|
template:
|
||||||
|
src: dhcp-host.j2
|
||||||
|
dest: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d/{{ inventory_hostname }}"
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
when: inventory_dhcp | bool == true
|
||||||
|
become: yes
|
||||||
|
- name: "Setup DNS address for nodes."
|
||||||
|
template:
|
||||||
|
src: dns-address.j2
|
||||||
|
dest: "/etc/dnsmasq.d/host_record_{{ inventory_hostname }}"
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
mode: 0644
|
||||||
|
when: inventory_dns | bool == true
|
||||||
|
become: yes
|
||||||
|
- name: "Sending dnsmasq HUP"
|
||||||
|
# Note(TheJulia): We need to actually to send a hup signal directly as
|
||||||
|
# Ansible's reloaded state does not pass through to the init script.
|
||||||
|
command: killall -HUP dnsmasq
|
||||||
|
become: yes
|
||||||
|
when: (inventory_dhcp | bool == true) or (inventory_dns | bool == true)
|
||||||
|
|
||||||
- name: "Execute node introspection"
|
- name: "Execute node introspection"
|
||||||
os_ironic_inspect:
|
os_ironic_inspect:
|
||||||
cloud: "{{ cloud_name | default(omit) }}"
|
cloud: "{{ cloud_name | default(omit) }}"
|
||||||
|
@ -0,0 +1,6 @@
|
|||||||
|
# This file is managed by bifrost
|
||||||
|
{% if inventory_dhcp_static_ip | bool == true %}
|
||||||
|
{{ nics[0]['mac'] }},{{provisioning_ipv4_address}},{{name}},12h
|
||||||
|
{% else %}
|
||||||
|
{{ nics[0]['mac'] }},{{name}},12h
|
||||||
|
{% endif %}
|
@ -0,0 +1,2 @@
|
|||||||
|
# This file is managed by bifrost
|
||||||
|
host-record={{ inventory_hostname }},{{ ipv4_address }}
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- Added dhcp configuration tasks to inspection role.
|
||||||
|
In case when inventory_dhcp is enabled and node is not deployed yet,
|
||||||
|
inspection is not working because dnsmasq ignores requests from unknown
|
||||||
|
address. This fix introduces tasks which configures dhcp before
|
||||||
|
inspection.
|
Loading…
x
Reference in New Issue
Block a user