Merge "Avoid shared IPA image cache on Ansible control host"
This commit is contained in:
commit
903126c018
@ -46,37 +46,6 @@
|
|||||||
when: not item.stat.exists
|
when: not item.stat.exists
|
||||||
tags:
|
tags:
|
||||||
- config-validation
|
- config-validation
|
||||||
|
|
||||||
- name: Check whether the image cache directory exists
|
|
||||||
local_action:
|
|
||||||
module: stat
|
|
||||||
path: "{{ hostvars.localhost.image_cache_path }}"
|
|
||||||
get_checksum: False
|
|
||||||
mime: False
|
|
||||||
register: image_cache_stat
|
|
||||||
|
|
||||||
- name: Ensure the image cache directory exists
|
|
||||||
local_action:
|
|
||||||
module: file
|
|
||||||
path: "{{ hostvars.localhost.image_cache_path }}"
|
|
||||||
state: directory
|
|
||||||
owner: "{{ lookup('env', 'USER') }}"
|
|
||||||
group: "{{ lookup('env', 'USER') }}"
|
|
||||||
become: True
|
|
||||||
when: >-
|
|
||||||
not image_cache_stat.stat.exists or
|
|
||||||
not image_cache_stat.stat.writeable
|
|
||||||
|
|
||||||
- name: Ensure Ironic Python Agent images are copied onto the local machine
|
|
||||||
fetch:
|
|
||||||
src: "{{ image_cache_path }}/{{ ipa_image_name }}/{{ item.src }}"
|
|
||||||
dest: "{{ hostvars.localhost.image_cache_path }}/{{ ipa_image_name }}/{{ item.dest }}"
|
|
||||||
flat: True
|
|
||||||
with_items:
|
|
||||||
- src: "{{ ipa_images[0] }}"
|
|
||||||
dest: "{{ ipa_images_kernel_name }}"
|
|
||||||
- src: "{{ ipa_images[1] }}"
|
|
||||||
dest: "{{ ipa_images_ramdisk_name }}"
|
|
||||||
when:
|
when:
|
||||||
- kolla_enable_ironic | bool
|
- kolla_enable_ironic | bool
|
||||||
- ipa_build_images | bool
|
- ipa_build_images | bool
|
||||||
@ -149,9 +118,11 @@
|
|||||||
|
|
||||||
- name: Set facts containing IPA kernel and ramdisk paths
|
- name: Set facts containing IPA kernel and ramdisk paths
|
||||||
set_fact:
|
set_fact:
|
||||||
kolla_inspector_ipa_kernel_path: "{{ image_cache_path }}/{{ ipa_image_name }}/{{ ipa_images_kernel_name }}"
|
kolla_inspector_ipa_kernel_path: "{{ hostvars[inspector_ipa_host].image_cache_path }}/{{ ipa_image_name }}/{{ ipa_images_kernel_name }}"
|
||||||
kolla_inspector_ipa_ramdisk_path: "{{ image_cache_path }}/{{ ipa_image_name }}/{{ ipa_images_ramdisk_name }}"
|
kolla_inspector_ipa_ramdisk_path: "{{ hostvars[inspector_ipa_host].image_cache_path }}/{{ ipa_image_name }}/{{ ipa_images_ramdisk_name }}"
|
||||||
when: ipa_build_images | bool
|
when: ipa_build_images | bool
|
||||||
|
vars:
|
||||||
|
inspector_ipa_host: "{{ groups['controllers_with_ironic_enabled_True'][0] }}"
|
||||||
when: kolla_enable_ironic | bool
|
when: kolla_enable_ironic | bool
|
||||||
tags:
|
tags:
|
||||||
- config
|
- config
|
||||||
@ -169,6 +140,7 @@
|
|||||||
kolla_inspector_swift_auth:
|
kolla_inspector_swift_auth:
|
||||||
auth_type: none
|
auth_type: none
|
||||||
endpoint_override: "http://{% raw %}{{ api_interface_address }}{% endraw %}:{{ inspector_store_port }}"
|
endpoint_override: "http://{% raw %}{{ api_interface_address }}{% endraw %}:{{ inspector_store_port }}"
|
||||||
|
kolla_inspector_ipa_host: "{{ groups['controllers_with_ironic_enabled_True'][0] }}"
|
||||||
kolla_openstack_custom_config_paths_extra_multi_env_static:
|
kolla_openstack_custom_config_paths_extra_multi_env_static:
|
||||||
- "{{ kayobe_config_path }}"
|
- "{{ kayobe_config_path }}"
|
||||||
kolla_openstack_custom_config_paths_extra_multi_env: "{{ kolla_openstack_custom_config_paths_extra_multi_env_static + kayobe_env_search_paths }}"
|
kolla_openstack_custom_config_paths_extra_multi_env: "{{ kolla_openstack_custom_config_paths_extra_multi_env_static + kayobe_env_search_paths }}"
|
||||||
|
@ -17,3 +17,7 @@ image_download_path:
|
|||||||
|
|
||||||
# Path to the image's destination.
|
# Path to the image's destination.
|
||||||
image_download_dest:
|
image_download_dest:
|
||||||
|
|
||||||
|
# Host from which to fetch the image.
|
||||||
|
# Only used when image_download_path is set.
|
||||||
|
image_download_host: "{{ inventory_hostname }}"
|
||||||
|
@ -9,8 +9,7 @@
|
|||||||
- name: Fail if the checksum algorithm is not set
|
- name: Fail if the checksum algorithm is not set
|
||||||
fail:
|
fail:
|
||||||
msg: "Checksum algorithm for image {{ image_download_url }} not set"
|
msg: "Checksum algorithm for image {{ image_download_url }} not set"
|
||||||
when: image_download_checksum_algorithm is none or
|
when: image_download_checksum_algorithm is falsy
|
||||||
image_download_checksum_algorithm == ""
|
|
||||||
|
|
||||||
- name: Get the expected checksum
|
- name: Get the expected checksum
|
||||||
uri:
|
uri:
|
||||||
@ -21,8 +20,7 @@
|
|||||||
retries: 3
|
retries: 3
|
||||||
delay: 5
|
delay: 5
|
||||||
when:
|
when:
|
||||||
- image_download_checksum_url is not none
|
- image_download_checksum_url is truthy
|
||||||
- image_download_checksum_url != ""
|
|
||||||
|
|
||||||
- name: Ensure the image is downloaded
|
- name: Ensure the image is downloaded
|
||||||
vars:
|
vars:
|
||||||
@ -42,14 +40,28 @@
|
|||||||
retries: 3
|
retries: 3
|
||||||
delay: 5
|
delay: 5
|
||||||
when:
|
when:
|
||||||
- image_download_url is not none
|
- image_download_url is truthy
|
||||||
- image_download_url != ""
|
|
||||||
|
|
||||||
- name: Ensure the local image is copied
|
- when: image_download_path is truthy
|
||||||
copy:
|
block:
|
||||||
src: "{{ image_download_path }}"
|
- name: Ensure the local image is copied
|
||||||
dest: "{{ image_download_dest }}"
|
copy:
|
||||||
mode: 0640
|
src: "{{ image_download_path }}"
|
||||||
when:
|
dest: "{{ image_download_dest }}"
|
||||||
- image_download_path is not none
|
mode: 0640
|
||||||
- image_download_path != ""
|
when:
|
||||||
|
- image_download_host is falsy
|
||||||
|
|
||||||
|
- name: Ensure the remote image is fetched
|
||||||
|
fetch:
|
||||||
|
src: "{{ image_download_path }}"
|
||||||
|
dest: "{{ image_download_dest }}"
|
||||||
|
mode: 0640
|
||||||
|
flat: true
|
||||||
|
when:
|
||||||
|
- image_download_host is truthy
|
||||||
|
delegate_to: "{{ image_download_host | default('localhost', true) }}"
|
||||||
|
vars:
|
||||||
|
# NOTE: Without this, the hosts's ansible_host variable will not be
|
||||||
|
# respected when using delegate_to.
|
||||||
|
ansible_host: "{{ hostvars[image_download_host].ansible_host | default(image_download_host) }}"
|
||||||
|
@ -617,6 +617,11 @@ kolla_inspector_ipa_kernel_path:
|
|||||||
# Mutually exclusive with kolla_inspector_ipa_ramdisk_upstream_url.
|
# Mutually exclusive with kolla_inspector_ipa_ramdisk_upstream_url.
|
||||||
kolla_inspector_ipa_ramdisk_path:
|
kolla_inspector_ipa_ramdisk_path:
|
||||||
|
|
||||||
|
# Host from which to fetch Ironic Python Agent (IPA) kernel and ramdisk images
|
||||||
|
# for Ironic Inspector. Only used when kolla_inspector_ipa_kernel_path or
|
||||||
|
# kolla_inspector_ipa_ramdisk_path is set.
|
||||||
|
kolla_inspector_ipa_host:
|
||||||
|
|
||||||
# Whether to enable the Swift introspection data store.
|
# Whether to enable the Swift introspection data store.
|
||||||
kolla_inspector_enable_swift:
|
kolla_inspector_enable_swift:
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
image_download_checksum_algorithm: "{{ item.checksum_algorithm }}"
|
image_download_checksum_algorithm: "{{ item.checksum_algorithm }}"
|
||||||
image_download_path: "{{ item.path }}"
|
image_download_path: "{{ item.path }}"
|
||||||
image_download_dest: "{{ item.dest }}"
|
image_download_dest: "{{ item.dest }}"
|
||||||
|
image_download_host: "{{ kolla_inspector_ipa_host }}"
|
||||||
include_role:
|
include_role:
|
||||||
name: image-download
|
name: image-download
|
||||||
with_items:
|
with_items:
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
Fixes an issue when using overcloud Ironic with a shared Ansible control
|
||||||
|
host. The use of a shared cache directory could lead to a failure to
|
||||||
|
download Ironic Python Agent (IPA) images. `LP#2069845
|
||||||
|
<https://bugs.launchpad.net/kayobe/+bug/2069845>`__
|
Loading…
Reference in New Issue
Block a user