CentOS 8: Use ansible_playbook_python for localhost dependencies

Currently we install python dependencies on the Ansible control host
each time the ip-allocation and console-allocation roles are executed.
This is inefficient, particularly in the case of the ip-allocation role
which is run serially for all hosts. It is also unnecessary since we
have these packages available in the Python environment used to execute
kayobe.

The kolla-ansible role also has an implicit dependency on PyYAML for
managing kolla passwords.

This change uses ansible_playbook_python as the Python interpreter for
the necessary tasks in these roles to avoid installing dependencies on
the system on CentOS 8 and Ubuntu. For CentOS 7 we still need to use the
platform Python, due to needing SELinux bindings.

Change-Id: Ic6a1c69a34241f4fbe617a0b12aec9b1528ba352
Story: 2006574
Task: 38825
This commit is contained in:
Mark Goddard 2020-02-20 16:05:06 +00:00
parent 2e842ab3f5
commit a91135179d
10 changed files with 88 additions and 69 deletions

View File

@ -40,6 +40,14 @@
{{ query('inventory_hostnames', console_compute_node_limit | {{ query('inventory_hostnames', console_compute_node_limit |
default('baremetal-compute') ) | unique }} default('baremetal-compute') ) | unique }}
# NOTE(mgoddard): This task may be removed when CentOS 7 is no longer
# supported.
- name: Gather facts for localhost
setup:
gather_subset: min
delegate_to: localhost
delegate_facts: true
- name: Reserve TCP ports for ironic serial consoles - name: Reserve TCP ports for ironic serial consoles
include_role: include_role:
name: console-allocation name: console-allocation

View File

@ -1,4 +1,21 @@
--- ---
# NOTE(mgoddard): We use delegate_to rather than specify localhost in the
# hosts list since this playbook is typically called with a limit that does
# not include localhost. This play may be removed when CentOS 7 is no longer
# supported.
- name: Gather facts for localhost
hosts: seed-hypervisor:seed:overcloud
tags:
- ip-allocation
gather_facts: no
tasks:
- name: Gather facts for localhost
setup:
gather_subset: min
delegate_to: localhost
delegate_facts: true
run_once: true
- name: Ensure IP addresses are allocated - name: Ensure IP addresses are allocated
hosts: seed-hypervisor:seed:overcloud hosts: seed-hypervisor:seed:overcloud
tags: tags:

View File

@ -1,32 +1,23 @@
--- ---
# Facts may not be available for the Ansible control host, so read the OS - block:
# release manually. - name: Include OS family-specific variables
- name: Check the OS release include_vars: "{{ hostvars.localhost.ansible_os_family }}.yml"
local_action:
module: shell . /etc/os-release && echo $ID
changed_when: False
register: console_allocation_os_release
- name: Include RedHat family-specific variables # Note: Currently we install these using the system package manager rather than
include_vars: "RedHat.yml" # pip to a virtualenv. This is because Yum is required elsewhere and cannot
when: console_allocation_os_release.stdout in ['centos', 'fedora', 'rhel'] # easily be installed in a virtualenv.
- name: Ensure package dependencies are installed
- name: Include Debian family-specific variables local_action:
include_vars: "Debian.yml" module: package
when: console_allocation_os_release.stdout in ['debian', 'ubuntu'] name: "{{ item }}"
state: present
# Note: Currently we install these using the system package manager rather than use: "{{ console_allocation_package_manager }}"
# pip to a virtualenv. This is because Yum is required elsewhere and cannot become: True
# easily be installed in a virtualenv. with_items: "{{ console_allocation_package_dependencies }}"
- name: Ensure package dependencies are installed run_once: True
local_action: when:
module: package - hostvars.localhost.ansible_os_family == 'RedHat'
name: "{{ item }}" - hostvars.localhost.ansible_distribution_major_version | int == 7
state: present
use: "{{ console_allocation_package_manager }}"
become: True
with_items: "{{ console_allocation_package_dependencies }}"
run_once: True
- name: Validate allocation pool start - name: Validate allocation pool start
vars: vars:
@ -60,6 +51,14 @@
- (console_allocation_pool_start | int) > (console_allocation_pool_end | int) - (console_allocation_pool_start | int) > (console_allocation_pool_end | int)
- name: Ensure Ironic serial console ports are allocated - name: Ensure Ironic serial console ports are allocated
vars:
# NOTE(mgoddard): Use the Python interpreter used to run ansible-playbook,
# since this has Python dependencies available to it (PyYAML). On CentOS 7
# we use the system Python to ensure that we can import SELinux bindings.
ansible_python_interpreter: >-
{{ '/usr/libexec/platform-python'
if hostvars.localhost.ansible_os_family == 'RedHat' and hostvars.localhost.ansible_distribution_major_version | int == 7
else ansible_playbook_python }}
local_action: local_action:
module: console_allocation module: console_allocation
allocation_file: "{{ console_allocation_filename }}" allocation_file: "{{ console_allocation_filename }}"

View File

@ -1,7 +0,0 @@
---
# Package manager to use.
console_allocation_package_manager: apt
# List of packages to install.
console_allocation_package_dependencies:
- python-yaml

View File

@ -1,34 +1,33 @@
--- ---
# Facts may not be available for the Ansible control host, so read the OS - block:
# release manually. - name: Include OS family-specific variables
- name: Check the OS release include_vars: "{{ hostvars.localhost.ansible_os_family }}.yml"
local_action:
module: shell . /etc/os-release && echo $ID
changed_when: False
register: ip_allocation_os_release
- name: Include RedHat family-specific variables # Note: Currently we install these using the system package manager rather than
include_vars: "RedHat.yml" # pip to a virtualenv. This is because Yum is required elsewhere and cannot
when: ip_allocation_os_release.stdout in ['centos', 'fedora', 'rhel'] # easily be installed in a virtualenv.
- name: Ensure package dependencies are installed
- name: Include Debian family-specific variables local_action:
include_vars: "Debian.yml" module: package
when: ip_allocation_os_release.stdout in ['debian', 'ubuntu'] name: "{{ item }}"
state: present
# Note: Currently we install these using the system package manager rather than use: "{{ ip_allocation_package_manager }}"
# pip to a virtualenv. This is because Yum is required elsewhere and cannot become: True
# easily be installed in a virtualenv. with_items: "{{ ip_allocation_package_dependencies }}"
- name: Ensure package dependencies are installed run_once: True
local_action: when:
module: package - hostvars.localhost.ansible_os_family == 'RedHat'
name: "{{ item }}" - hostvars.localhost.ansible_distribution_major_version | int == 7
state: present
use: "{{ ip_allocation_package_manager }}"
become: True
with_items: "{{ ip_allocation_package_dependencies }}"
run_once: True
- name: Ensure IP addresses are allocated - name: Ensure IP addresses are allocated
vars:
# NOTE(mgoddard): Use the Python interpreter used to run ansible-playbook,
# since this has Python dependencies available to it (PyYAML). On CentOS 7
# we use the system Python to ensure that we can import SELinux bindings.
ansible_python_interpreter: >-
{{ '/usr/libexec/platform-python'
if hostvars.localhost.ansible_os_family == 'RedHat' and hostvars.localhost.ansible_distribution_major_version | int == 7
else ansible_playbook_python }}
local_action: local_action:
module: ip_allocation module: ip_allocation
allocation_file: "{{ ip_allocation_filename }}" allocation_file: "{{ ip_allocation_filename }}"

View File

@ -1,8 +0,0 @@
---
# Package manager to use.
ip_allocation_package_manager: apt
# List of packages to install.
ip_allocation_package_dependencies:
- python-netaddr
- python-yaml

View File

@ -97,6 +97,14 @@
loop_var: host loop_var: host
- name: Ensure the Kolla passwords file exists - name: Ensure the Kolla passwords file exists
vars:
# NOTE(mgoddard): Use the Python interpreter used to run ansible-playbook,
# since this has Python dependencies available to it (PyYAML). On CentOS 7
# we use the system Python to ensure that we can import SELinux bindings.
ansible_python_interpreter: >-
{{ '/usr/libexec/platform-python'
if ansible_os_family == 'RedHat' and ansible_distribution_major_version | int == 7
else ansible_playbook_python }}
kolla_passwords: kolla_passwords:
src: "{{ kolla_ansible_passwords_path }}" src: "{{ kolla_ansible_passwords_path }}"
dest: "{{ kolla_ansible_passwords_path }}" dest: "{{ kolla_ansible_passwords_path }}"

View File

@ -8,3 +8,4 @@ kolla_ansible_package_dependencies:
- "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-dev" - "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-dev"
- "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-pip" - "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-pip"
- "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3-venv{% else %}-virtualenv{% endif %}" - "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3-venv{% else %}-virtualenv{% endif %}"
- "{% if kolla_ansible_venv_python_major_version | int == 2 %}python-yaml{% endif %}"

View File

@ -8,3 +8,4 @@ kolla_ansible_package_dependencies:
- "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-devel" - "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-devel"
- "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-pip" - "python{% if kolla_ansible_venv_python_major_version | int == 3 %}3{% endif %}-pip"
- "{% if kolla_ansible_venv_python_major_version | int == 2 %}python-virtualenv{% endif %}" - "{% if kolla_ansible_venv_python_major_version | int == 2 %}python-virtualenv{% endif %}"
- "{% if kolla_ansible_venv_python_major_version | int == 2 %}PyYAML{% endif %}"

View File

@ -8,3 +8,4 @@ cliff>=2.5.0,<2.15.0 # Apache
netaddr!=0.7.16,>=0.7.13 # BSD netaddr!=0.7.16,>=0.7.13 # BSD
PyYAML>=3.10.0 # MIT PyYAML>=3.10.0 # MIT
setuptools!=24.0.0,!=34.0.0,!=34.0.1,!=34.0.2,!=34.0.3,!=34.1.0,!=34.1.1,!=34.2.0,!=34.3.0,!=34.3.1,>=16.0 # PSF/ZPL setuptools!=24.0.0,!=34.0.0,!=34.0.1,!=34.0.2,!=34.0.3,!=34.1.0,!=34.1.1,!=34.2.0,!=34.3.0,!=34.3.1,>=16.0 # PSF/ZPL
selinux;python_version>='3' # MIT