mirror of https://github.com/ceph/ceph-ansible.git
update: support --limit on monitor nodes
Change needed in order to support --limit on mon nodes.
Otherwise, a call to `hostvars[groups[mon_group_name][0]]['_current_monitor_address']`
throws an error:
```
"The error was: 'ansible.vars.hostvars.HostVarsVars object' has no attribute '_current_monitor_address'"
```
Closes: https://bugzilla.redhat.com/show_bug.cgi?id=2014304#c28
Signed-off-by: Guillaume Abrioux <gabrioux@redhat.com>
(cherry picked from commit 82eee4303b
)
pull/6987/head
parent
a752edbd29
commit
8f648269ec
|
@ -273,6 +273,13 @@
|
||||||
when: inventory_hostname in groups[mgr_group_name] | default([])
|
when: inventory_hostname in groups[mgr_group_name] | default([])
|
||||||
or groups[mgr_group_name] | default([]) | length == 0
|
or groups[mgr_group_name] | default([]) | length == 0
|
||||||
|
|
||||||
|
- name: import_role ceph-facts
|
||||||
|
import_role:
|
||||||
|
name: ceph-facts
|
||||||
|
tasks_from: set_monitor_address.yml
|
||||||
|
delegate_to: "{{ groups[mon_group_name][0] }}"
|
||||||
|
delegate_facts: true
|
||||||
|
|
||||||
- name: non container | waiting for the monitor to join the quorum...
|
- name: non container | waiting for the monitor to join the quorum...
|
||||||
command: ceph --cluster "{{ cluster }}" -m "{{ hostvars[groups[mon_group_name][0]]['_current_monitor_address'] }}" quorum_status --format json
|
command: ceph --cluster "{{ cluster }}" -m "{{ hostvars[groups[mon_group_name][0]]['_current_monitor_address'] }}" quorum_status --format json
|
||||||
register: ceph_health_raw
|
register: ceph_health_raw
|
||||||
|
|
|
@ -54,4 +54,6 @@
|
||||||
set_fact:
|
set_fact:
|
||||||
_current_monitor_address: "{{ item.addr }}"
|
_current_monitor_address: "{{ item.addr }}"
|
||||||
with_items: "{{ _monitor_addresses }}"
|
with_items: "{{ _monitor_addresses }}"
|
||||||
when: inventory_hostname == item.name
|
when:
|
||||||
|
- (inventory_hostname == item.name and not rolling_update | default(False) | bool)
|
||||||
|
or (rolling_update | default(False) | bool and item.name == groups.get(mon_group_name, [])[0])
|
|
@ -56,7 +56,17 @@ commands=
|
||||||
"'
|
"'
|
||||||
|
|
||||||
# upgrade mons
|
# upgrade mons
|
||||||
ansible-playbook -vv -i {changedir}/{env:INVENTORY} {toxinidir}/infrastructure-playbooks/rolling_update.yml --tags=mons --extra-vars "\
|
# mon1
|
||||||
|
ansible-playbook -vv -i {changedir}/{env:INVENTORY} {toxinidir}/infrastructure-playbooks/rolling_update.yml --limit mon1 --tags=mons --extra-vars "\
|
||||||
|
ireallymeanit=yes \
|
||||||
|
ceph_dev_branch={env:UPDATE_CEPH_DEV_BRANCH:master} \
|
||||||
|
ceph_dev_sha1={env:UPDATE_CEPH_DEV_SHA1:latest} \
|
||||||
|
ceph_docker_registry_auth=True \
|
||||||
|
ceph_docker_registry_username={env:DOCKER_HUB_USERNAME} \
|
||||||
|
ceph_docker_registry_password={env:DOCKER_HUB_PASSWORD} \
|
||||||
|
"
|
||||||
|
# mon0 and mon2
|
||||||
|
ansible-playbook -vv -i {changedir}/{env:INVENTORY} {toxinidir}/infrastructure-playbooks/rolling_update.yml --limit 'mons:!mon1' --tags=mons --extra-vars "\
|
||||||
ireallymeanit=yes \
|
ireallymeanit=yes \
|
||||||
ceph_docker_registry_auth=True \
|
ceph_docker_registry_auth=True \
|
||||||
ceph_docker_registry_username={env:DOCKER_HUB_USERNAME} \
|
ceph_docker_registry_username={env:DOCKER_HUB_USERNAME} \
|
||||||
|
|
Loading…
Reference in New Issue