Introduce heat as new provisioner
This change introduces OpenStack Heat as new provisioner.
Notes about how it is expected to work.
- Below heat templates are created without parameter defaults
as they differ depending on OpenStack Cloud where the instances
are created and number of instances to be created.
- provisioner/heat/playbooks/roles/install-configure-heat/files/heat-template.yaml
- provisioner/heat/playbooks/roles/install-configure-heat/files/heat-server.yaml
- Parameters in provided heat-template.yaml are expected to be set by the user
provided heat environment file using argument -e <uri to heat environment file> as
they are specific to OpenStack Cloud and the scenario. If user does not provide
heat environment file, the engine will use the default environment file to set
the parameter values which is pretty conservative.
- provisioner/heat/playbooks/roles/install-configure-heat/files/heat-environment.yaml
- As the instances are provisioned from OpenStack Cloud and also due to
not having PDF and IDF for them, configure-network role is skipped
for these instances. This could be looked into in future when the need
arises.
Another thing to note is that even though the engine is run within Python virtualenv,
Ansible OpenStack module doesn't seem to respect to this and uses system Python. This
causes execution of engine with Heat as provisioner fail with below error.
fatal: [localhost]: FAILED! => {"changed": false, "msg": "openstacksdk is required for this module"}
This is due to that Ansible OpenStack module looks in system Python which doesn't have
the package openstacksdk installed since we install it in virtualenv.
This change explicitly sets ansible_python_interpreter to be the one that is in
in virtualenv.
Change-Id: I1d9e5c722d4a0fe4dfd14ef3fa06b1e01c44aabc
diff --git a/playbooks/roles/configure-targethosts/tasks/configure-network.yml b/playbooks/roles/configure-targethosts/tasks/configure-network.yml
index 5d062c5..65f0c88 100644
--- a/playbooks/roles/configure-targethosts/tasks/configure-network.yml
+++ b/playbooks/roles/configure-targethosts/tasks/configure-network.yml
@@ -17,13 +17,13 @@
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
-- name: Get node name from IDF for host "{{ inventory_hostname }}"
+- name: Get node names from IDF
set_fact:
node_name: "{{ item.key }}"
with_dict: "{{ idf.kubespray.hostnames }}"
when: item.value == inventory_hostname
-- name: Set facts for the node "{{ node_name }}"
+- name: Set facts for the nodes
set_fact:
node: "{{ nodes | selectattr('name', 'equalto', node_name) | first }}"
@@ -43,7 +43,7 @@
when:
idf.proxy_settings is defined
-- name: Add proxy settings to /etc/environment on target node
+- name: Add proxy settings to /etc/environment on target nodes
lineinfile:
dest: /etc/environment
state: present
diff --git a/playbooks/roles/configure-targethosts/tasks/main.yml b/playbooks/roles/configure-targethosts/tasks/main.yml
index 58a78fb..b46dbe4 100644
--- a/playbooks/roles/configure-targethosts/tasks/main.yml
+++ b/playbooks/roles/configure-targethosts/tasks/main.yml
@@ -17,7 +17,11 @@
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
+# TODO: for the nodes provisioned from openstack using heat, we might not need
+# to adjust the network. apart from that, we don't have pdf & idf for them so
+# it is tricky to make it work quickly so we skip it for those nodes
- include: configure-network.yml
+ when: provisioner_type == "bifrost"
- include: install-packages.yml
- include: sync-time.yml