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:
parent
2e842ab3f5
commit
a91135179d
@ -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
|
||||||
|
@ -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:
|
||||||
|
@ -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 }}"
|
||||||
|
@ -1,7 +0,0 @@
|
|||||||
---
|
|
||||||
# Package manager to use.
|
|
||||||
console_allocation_package_manager: apt
|
|
||||||
|
|
||||||
# List of packages to install.
|
|
||||||
console_allocation_package_dependencies:
|
|
||||||
- python-yaml
|
|
@ -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 }}"
|
||||||
|
@ -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
|
|
@ -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 }}"
|
||||||
|
@ -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 %}"
|
||||||
|
@ -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 %}"
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user