Re-deploy the Aodh venv if it mismatches the repo
We currently have two issues with venvs:
- if you update your venv on the repo server, it is not possible for
that updated venv to land on the service's container as the get_url
task always skips if the file exists (even if the file is different)
- if you have an updated venv on the repo server and forcefully delete
the cached venv tarball on the service's container, the new tarball
will get unarchived over top of the existing venv
This commit does the following:
- gets the checksum of the /var/cache tarball and downloads checksum
file from repo server
- updates "Attempt venv download" to only download the venv if the
cache doesn't exist or if the local and remote checksums differ
- adds a "force: true" to "Attempt venv download" task so that the venv
tarball will get re-downloaded when the when condition is true (this
is necessary otherwise the download will get skipped since the
destination already exists)
- adds a new task "Remove existing venv" so we can first remove the
venv before we unarchive the potentially new venv from the repo
server
- updates "Create aodh venv dir" and "Unarchive pre-built venv"
tasks to only proceed if "aodh_get_venv | changed", which
prevents these tasks from running when they the venv tarball hasn't
changed
- adds multiple service restarts to
os_aodh/tasks/aodh_install.yml so that aodh will restart
correctly should the venv/packages update without any associated
config changes
NOTE: The reason why we compare local and remote checksum is to avoid
unnecessarily downloading the venv when the checksums are in fact
the same. On small deploys this is more or less a non-issue but
if a deploy w/ thousands of compute nodes re-runs playbooks we
want to limit the venv downloads when it's unnecessary.
Change-Id: Ic3773c4d6e8e62e2b9dc0203190b2fba675afc59
This commit is contained in:
@@ -91,6 +91,7 @@ aodh_requires_pip_packages:
|
|||||||
- virtualenv
|
- virtualenv
|
||||||
- virtualenv-tools
|
- virtualenv-tools
|
||||||
- python-keystoneclient # Keystoneclient needed to OSA keystone lib
|
- python-keystoneclient # Keystoneclient needed to OSA keystone lib
|
||||||
|
- httplib2
|
||||||
|
|
||||||
# Common pip packages
|
# Common pip packages
|
||||||
aodh_pip_packages:
|
aodh_pip_packages:
|
||||||
|
|||||||
@@ -43,13 +43,42 @@
|
|||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
|
|
||||||
|
- name: Get local venv checksum
|
||||||
|
stat:
|
||||||
|
path: "/var/cache/{{ aodh_venv_download_url | basename }}"
|
||||||
|
get_md5: False
|
||||||
|
when: aodh_venv_enabled | bool
|
||||||
|
register: local_venv_stat
|
||||||
|
tags:
|
||||||
|
- aodh-install
|
||||||
|
- aodh-pip-packages
|
||||||
|
|
||||||
|
- name: Get remote venv checksum
|
||||||
|
uri:
|
||||||
|
url: "{{ aodh_venv_download_url | replace('tgz', 'checksum') }}"
|
||||||
|
return_content: True
|
||||||
|
when: aodh_venv_enabled | bool
|
||||||
|
register: remote_venv_checksum
|
||||||
|
tags:
|
||||||
|
- aodh-install
|
||||||
|
- aodh-pip-packages
|
||||||
|
|
||||||
|
# TODO: When project moves to ansible 2 we can pass this a sha256sum which will:
|
||||||
|
# a) allow us to remove force: yes
|
||||||
|
# b) allow the module to calculate the checksum of dest file which would
|
||||||
|
# result in file being downloaded only if provided and dest sha256sum
|
||||||
|
# checksums differ
|
||||||
- name: Attempt venv download
|
- name: Attempt venv download
|
||||||
get_url:
|
get_url:
|
||||||
url: "{{ aodh_venv_download_url }}"
|
url: "{{ aodh_venv_download_url }}"
|
||||||
dest: "/var/cache/{{ aodh_venv_download_url | basename }}"
|
dest: "/var/cache/{{ aodh_venv_download_url | basename }}"
|
||||||
|
force: yes
|
||||||
ignore_errors: true
|
ignore_errors: true
|
||||||
register: get_venv
|
register: get_venv
|
||||||
when: aodh_venv_enabled | bool
|
when:
|
||||||
|
- aodh_venv_enabled | bool
|
||||||
|
- (local_venv_stat.stat.exists == False or
|
||||||
|
{{ local_venv_stat.stat.checksum is defined and local_venv_stat.stat.checksum != remote_venv_checksum.content | trim }})
|
||||||
tags:
|
tags:
|
||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
@@ -62,13 +91,24 @@
|
|||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
|
|
||||||
|
- name: Remove existing venv
|
||||||
|
file:
|
||||||
|
path: "{{ aodh_venv_bin | dirname }}"
|
||||||
|
state: absent
|
||||||
|
when:
|
||||||
|
- aodh_venv_enabled | bool
|
||||||
|
- aodh_get_venv | changed
|
||||||
|
tags:
|
||||||
|
- aodh-install
|
||||||
|
- aodh-pip-packages
|
||||||
|
|
||||||
- name: Create aodh venv dir
|
- name: Create aodh venv dir
|
||||||
file:
|
file:
|
||||||
path: "{{ aodh_venv_bin | dirname }}"
|
path: "{{ aodh_venv_bin | dirname }}"
|
||||||
state: directory
|
state: directory
|
||||||
when:
|
when:
|
||||||
- aodh_venv_enabled | bool
|
- aodh_venv_enabled | bool
|
||||||
- aodh_get_venv | success
|
- aodh_get_venv | changed
|
||||||
tags:
|
tags:
|
||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
@@ -80,7 +120,8 @@
|
|||||||
copy: "no"
|
copy: "no"
|
||||||
when:
|
when:
|
||||||
- aodh_venv_enabled | bool
|
- aodh_venv_enabled | bool
|
||||||
- aodh_get_venv | success
|
- aodh_get_venv | changed
|
||||||
|
notify: Restart aodh services
|
||||||
tags:
|
tags:
|
||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
@@ -111,6 +152,7 @@
|
|||||||
when:
|
when:
|
||||||
- aodh_venv_enabled | bool
|
- aodh_venv_enabled | bool
|
||||||
- aodh_get_venv | failed
|
- aodh_get_venv | failed
|
||||||
|
notify: Restart aodh services
|
||||||
tags:
|
tags:
|
||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
@@ -127,6 +169,7 @@
|
|||||||
with_items:
|
with_items:
|
||||||
- "{{ aodh_pip_packages }}"
|
- "{{ aodh_pip_packages }}"
|
||||||
when: not aodh_venv_enabled | bool
|
when: not aodh_venv_enabled | bool
|
||||||
|
notify: Restart aodh services
|
||||||
tags:
|
tags:
|
||||||
- aodh-install
|
- aodh-install
|
||||||
- aodh-pip-packages
|
- aodh-pip-packages
|
||||||
|
|||||||
Reference in New Issue
Block a user