--- - name: check if it is atomic host stat: path: /run/ostree-booted register: stat_ostree - name: set_fact is_atomic set_fact: is_atomic: "{{ stat_ostree.stat.exists }}" - name: set_fact monitor_name ansible_hostname set_fact: monitor_name: "{{ ansible_hostname }}" when: - not mon_use_fqdn - name: set_fact monitor_name ansible_fqdn set_fact: monitor_name: "{{ ansible_fqdn }}" when: - mon_use_fqdn - name: set_fact docker_exec_cmd set_fact: docker_exec_cmd: "docker exec ceph-mon-{{ hostvars[groups[mon_group_name][0]]['ansible_hostname'] }}" delegate_to: "{{ groups[mon_group_name][0] }}" when: - containerized_deployment - groups.get(mon_group_name, []) | length > 0 # this task shouldn't run in a rolling_update situation # because it blindly picks a mon, which may be down because # of the rolling update - name: is ceph running already? command: "timeout 5 {{ docker_exec_cmd }} ceph --cluster {{ cluster }} fsid" changed_when: false failed_when: false check_mode: no register: ceph_current_fsid run_once: true delegate_to: "{{ groups[mon_group_name][0] }}" when: - not rolling_update - groups.get(mon_group_name, []) | length > 0 # We want this check to be run only on the first node - name: check if {{ fetch_directory }} directory exists local_action: module: stat path: "{{ fetch_directory }}/monitor_keyring.conf" become: false register: monitor_keyring_conf run_once: true # set this as a default when performing a rolling_update # so the rest of the tasks here will succeed - name: set_fact ceph_current_fsid rc 1 set_fact: ceph_current_fsid: rc: 1 when: - rolling_update or groups.get(mon_group_name, []) | length == 0 - name: create a local fetch directory if it does not exist local_action: module: file path: "{{ fetch_directory }}" state: directory changed_when: false become: false when: - (cephx or generate_fsid) - name: set_fact fsid ceph_current_fsid.stdout set_fact: fsid: "{{ ceph_current_fsid.stdout }}" when: - ceph_current_fsid.get('rc', 1) == 0 # Set ceph_release to ceph_stable by default - name: set_fact ceph_release ceph_stable_release set_fact: ceph_release: "{{ ceph_stable_release }}" - name: generate cluster fsid local_action: module: shell python -c 'import uuid; print(str(uuid.uuid4()))' | tee {{ fetch_directory }}/ceph_cluster_uuid.conf creates: "{{ fetch_directory }}/ceph_cluster_uuid.conf" register: cluster_uuid become: false when: - generate_fsid - ceph_current_fsid.rc != 0 - name: reuse cluster fsid when cluster is already running local_action: module: shell echo {{ fsid }} | tee {{ fetch_directory }}/ceph_cluster_uuid.conf creates: "{{ fetch_directory }}/ceph_cluster_uuid.conf" become: false when: - ceph_current_fsid.get('rc', 1) == 0 - name: read cluster fsid if it already exists local_action: module: command cat {{ fetch_directory }}/ceph_cluster_uuid.conf removes: "{{ fetch_directory }}/ceph_cluster_uuid.conf" changed_when: false register: cluster_uuid become: false check_mode: no when: - generate_fsid - name: set_fact fsid set_fact: fsid: "{{ cluster_uuid.stdout }}" when: - generate_fsid - name: set_fact mds_name ansible_hostname set_fact: mds_name: "{{ ansible_hostname }}" when: - not mds_use_fqdn - name: set_fact mds_name ansible_fqdn set_fact: mds_name: "{{ ansible_fqdn }}" when: - mds_use_fqdn - name: set_fact rbd_client_directory_owner ceph set_fact: rbd_client_directory_owner: ceph when: - rbd_client_directory_owner is not defined or not rbd_client_directory_owner - name: set_fact rbd_client_directory_group rbd_client_directory_group set_fact: rbd_client_directory_group: ceph when: - rbd_client_directory_group is not defined or not rbd_client_directory_group - name: set_fact rbd_client_directory_mode 0770 set_fact: rbd_client_directory_mode: "0770" when: - rbd_client_directory_mode is not defined or not rbd_client_directory_mode - name: resolve device link(s) command: readlink -f {{ item }} changed_when: false with_items: "{{ devices }}" register: devices_prepare_canonicalize when: - devices is defined - inventory_hostname in groups.get(osd_group_name, []) - not osd_auto_discovery|default(False) - osd_scenario|default('dummy') != 'lvm' - name: set_fact build devices from resolved symlinks set_fact: devices: "{{ devices | default([]) + [ item.stdout ] }}" with_items: "{{ devices_prepare_canonicalize.results }}" when: - devices is defined - inventory_hostname in groups.get(osd_group_name, []) - not osd_auto_discovery|default(False) - osd_scenario|default('dummy') != 'lvm' - name: set_fact build final devices list set_fact: devices: "{{ devices | reject('search','/dev/disk') | list | unique }}" when: - devices is defined - inventory_hostname in groups.get(osd_group_name, []) - not osd_auto_discovery|default(False) - osd_scenario|default('dummy') != 'lvm' - name: set_fact ceph_uid for debian based system - non container set_fact: ceph_uid: 64045 when: - not containerized_deployment - ansible_os_family == 'Debian' - name: set_fact ceph_uid for red hat or suse based system - non container set_fact: ceph_uid: 167 when: - not containerized_deployment - ansible_os_family in ['RedHat', 'Suse'] - name: set_fact ceph_uid for debian based system - container set_fact: ceph_uid: 64045 when: - containerized_deployment - ceph_docker_image_tag | search("ubuntu") - name: set_fact ceph_uid for red hat based system - container set_fact: ceph_uid: 167 when: - containerized_deployment - ceph_docker_image_tag | search("latest") or ceph_docker_image_tag | search("centos") or ceph_docker_image_tag | search("fedora") - name: set_fact ceph_uid for red hat set_fact: ceph_uid: 167 when: - containerized_deployment - ceph_docker_image | search("rhceph") - block: - name: get current cluster status (if already running) command: "{{ docker_exec_cmd }} ceph --cluster {{ cluster }} -s -f json" changed_when: false failed_when: false check_mode: no run_once: true delegate_to: "{{ groups[mon_group_name][0] }}" when: - not rolling_update - groups.get(mon_group_name, []) | length > 0 register: ceph_current_status - name: set_fact ceph_current_status (convert to json) set_fact: ceph_current_status: "{{ ceph_current_status.stdout | from_json }}" - name: set_fact rgw_hostname set_fact: rgw_hostname: "{% for key in ceph_current_status['servicemap']['services']['rgw']['daemons'].keys() %}{% if key == ansible_fqdn %}{{ key }}{% endif %}{% endfor %}" when: - ceph_current_fsid.get('rc', 1) == 0 - inventory_hostname in groups.get(rgw_group_name, []) # no servicemap before luminous - ceph_release_num[ceph_release] >= ceph_release_num['luminous'] - ansible_hostname != ansible_fqdn - name: set_fact rgw_hostname set_fact: rgw_hostname: "{{ ansible_hostname }}" when: - rgw_hostname is undefined