Do not archive ceph-ansible fetch directory if it is empty

There are conditions, e.g. external ceph deployment, where
ceph-ansible will not produce a fetch directory so we should
not always assume there is something to archive.

Add a task to register the contents of the ceph-ansible fetch
directory and only archive that directory if the contents exist.

Also, remove the '--no-overwrite-dir' option from tar as it
seems to have broken repeat deployments.

Change-Id: I56eae30d73bf5cc6b1ae413c6841f86c2a4e86b5
Closes-Bug: #1823759
Closes-Bug: #1823229
This commit is contained in:
John Fulton 2019-04-08 12:25:33 -04:00
parent 428b698b53
commit 031f5fb610

View File

@ -532,7 +532,7 @@ outputs:
ignore_errors: True ignore_errors: True
- name: untar local backup of ceph-ansible fetch directory - name: untar local backup of ceph-ansible fetch directory
# unarchive module hit https://github.com/ansible/ansible/issues/35645 # unarchive module hit https://github.com/ansible/ansible/issues/35645
shell: "/usr/bin/gtar --gzip --extract --no-overwrite-dir --file {{local_ceph_ansible_fetch_directory_backup}}/{{ceph_ansible_tarball_name}} -C {{playbook_dir}}/ceph-ansible/fetch_dir" shell: "/usr/bin/gtar --gzip --extract --file {{local_ceph_ansible_fetch_directory_backup}}/{{ceph_ansible_tarball_name}} -C {{playbook_dir}}/ceph-ansible/fetch_dir"
when: local_backup_file.stat.exists == True when: local_backup_file.stat.exists == True
when: local_ceph_ansible_fetch_directory_backup != "" when: local_ceph_ansible_fetch_directory_backup != ""
- block: # swift backup - block: # swift backup
@ -555,7 +555,7 @@ outputs:
- curl_get_http_status.stdout != "404" # new deployment - curl_get_http_status.stdout != "404" # new deployment
- name: unpack downloaded ceph-ansible fetch tarball to fetch directory - name: unpack downloaded ceph-ansible fetch tarball to fetch directory
# unarchive module hit https://github.com/ansible/ansible/issues/35645 # unarchive module hit https://github.com/ansible/ansible/issues/35645
shell: "/usr/bin/gtar --gzip --extract --no-overwrite-dir --file /tmp/{{old_ceph_ansible_tarball_name}} -C {{playbook_dir}}/ceph-ansible/fetch_dir" shell: "/usr/bin/gtar --gzip --extract --file /tmp/{{old_ceph_ansible_tarball_name}} -C {{playbook_dir}}/ceph-ansible/fetch_dir"
when: when:
- curl_get_http_status.changed - curl_get_http_status.changed
- curl_get_http_status.stdout == "200" - curl_get_http_status.stdout == "200"
@ -619,6 +619,11 @@ outputs:
when: when:
- outputs.changed - outputs.changed
- outputs.rc != 0 - outputs.rc != 0
- name: register contents of fetch_directory after ceph-ansible run
find:
paths: "{{playbook_dir}}/ceph-ansible/fetch_dir/"
recurse: true
register: ceph_ansible_fetch_dir_contents
- name: create ceph-ansible fetch directory tarball in local backup - name: create ceph-ansible fetch directory tarball in local backup
archive: archive:
path: "{{playbook_dir}}/ceph-ansible/fetch_dir/*" path: "{{playbook_dir}}/ceph-ansible/fetch_dir/*"
@ -626,7 +631,9 @@ outputs:
exclude_path: exclude_path:
- '{{playbook_dir}}/ceph-ansible/fetch_dir/fetch_dir' - '{{playbook_dir}}/ceph-ansible/fetch_dir/fetch_dir'
register: nested register: nested
when: local_ceph_ansible_fetch_directory_backup != "" when:
- local_ceph_ansible_fetch_directory_backup != ""
- ceph_ansible_fetch_dir_contents.matched|int != 0
- block: # swift backup - block: # swift backup
- name: create temporary ceph-ansible fetch directory tarball for swift backup - name: create temporary ceph-ansible fetch directory tarball for swift backup
archive: archive:
@ -651,7 +658,9 @@ outputs:
state: absent state: absent
when: (curl_put_http_status.changed and (curl_put_http_status.stdout == "200" or when: (curl_put_http_status.changed and (curl_put_http_status.stdout == "200" or
curl_put_http_status.stdout == "201")) curl_put_http_status.stdout == "201"))
when: local_ceph_ansible_fetch_directory_backup == "" when:
- local_ceph_ansible_fetch_directory_backup == ""
- ceph_ansible_fetch_dir_contents.matched|int != 0
- name: remove nested broken path if exist - name: remove nested broken path if exist
file: file:
state: absent state: absent