+++ /dev/null
----
-# Defines deployment design and assigns role to server groups
-
-- hosts:
- - mons
- - agents
- - osds
- - mdss
- - rgws
- - nfss
- - rbdmirrors
- - clients
- - iscsigws
- - iscsi-gws # for backward compatibility only!
- - mgrs
-
- gather_facts: false
- become: True
- any_errors_fatal: true
-
- vars:
- delegate_facts_host: True
-
- tasks:
- # pre-tasks for following import -
- - name: gather facts
- setup:
- when:
- - not delegate_facts_host | bool
-
- - name: gather and delegate facts
- setup:
- delegate_to: "{{ item }}"
- delegate_facts: True
- with_items: "{{ groups['all'] }}"
- run_once: true
- when:
- - delegate_facts_host | bool
-
- - name: check if it is atomic host
- stat:
- path: /run/ostree-booted
- register: stat_ostree
- tags:
- - always
-
- - name: set_fact is_atomic
- set_fact:
- is_atomic: '{{ stat_ostree.stat.exists }}'
- tags:
- - always
-
- - name: check if podman binary is present
- stat:
- path: /usr/bin/podman
- register: podman_binary
- tags:
- - always
-
- - name: set_fact is_podman
- set_fact:
- is_podman: "{{ podman_binary.stat.exists }}"
- when: is_atomic
- tags:
- - always
-
- - name: set_fact container_binary
- set_fact:
- container_binary: "{{ 'podman' if is_atomic and is_podman else 'docker' }}"
- tags:
- - always
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: [with_pkg, fetch_container_image]
- - import_role:
- name: ceph-validate
- private: false
- - import_role:
- name: ceph-infra
- private: false
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- tags: [with_pkg, fetch_container_image]
- when:
- - not (is_atomic | bool)
- - (not (inventory_hostname in groups.get('clients', [])) or (inventory_hostname == groups.get('clients', [''])|first))
-
-
- # post-tasks for upcoming import -
- - name: "pull {{ ceph_docker_image }} image"
- command: "{{ container_binary }} pull {{ ceph_docker_registry}}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
- changed_when: false
- when:
- - is_atomic
- - (ceph_docker_dev_image is undefined or not ceph_docker_dev_image)
- - (not (inventory_hostname in groups.get('clients', [])) or (inventory_hostname == groups.get('clients', [''])|first))
-
-- hosts: mons
- tasks:
- - name: set ceph monitor install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mon:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: mons
- become: True
- gather_facts: false
- tasks:
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-mon
- private: false
- serial: 1 # MUST be '1' WHEN DEPLOYING MONITORS ON DOCKER CONTAINERS
-
-- hosts: mons
- tasks:
- - name: set ceph monitor install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mon:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: mgrs
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph manager install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mgr:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: fals
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-mgr
- private: false
-
- # post-tasks for upcoming imports -
- - name: set ceph manager install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mgr:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: osds
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for upcoming imports -
- - name: set ceph osd install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_osd:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-osd
- private: false
-
- # post-tasks for preceding imports -
- - name: set ceph osd install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_osd:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: mdss
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph mds install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mds:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-mds
- private: false
-
- # post-tasks for preceding imports -
- - name: set ceph mds install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_mds:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: rgws
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph rgw install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_rgw:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-rgw
- private: false
-
- # post-tasks for preceding imports -
- - name: set ceph rgw install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_rgw:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: nfss
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph nfs install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_nfs:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-nfs
- private: false
-
- # post-tasks for following imports -
- - name: set ceph nfs install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_nfs:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: rbdmirrors
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph rbd mirror install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_rbdmirror:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-rbd-mirror
- private: false
-
- # post-tasks for preceding imports -
- - name: set ceph rbd mirror install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_rbdmirror:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: clients
- become: True
- gather_facts: false
- tasks:
- # pre-tasks for following imports -
- - name: set ceph client install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_client:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- when:
- - inventory_hostname == groups.get('clients', ['']) | first
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-client
- private: false
-
- # post-tasks for preceding imports -
- - name: set ceph client install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_client:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts:
- - iscsigws
- - iscsi-gws # for backward compatibility only!
- gather_facts: false
- become: True
- tasks:
- # pre-tasks for following imports -
- - name: set ceph iscsi gateway install 'In Progress'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_iscsi_gw:
- status: "In Progress"
- start: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
- - import_role:
- name: ceph-defaults
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-handler
- private: false
- - import_role:
- name: ceph-container-common
- private: false
- - import_role:
- name: ceph-config
- private: false
- tags: ['ceph_update_config']
- - import_role:
- name: ceph-iscsi-gw
- private: false
-
- # post-tasks for preceding imports -
- post_tasks:
- - name: set ceph iscsi gw install 'Complete'
- run_once: true
- set_stats:
- data:
- installer_phase_ceph_iscsi_gw:
- status: "Complete"
- end: "{{ lookup('pipe', 'date +%Y%m%d%H%M%SZ') }}"
-
-- hosts: mons
- gather_facts: false
- become: True
- tasks:
- - name: get ceph status from the first monitor
- command: docker exec ceph-mon-{{ hostvars[groups['mons'][0]]['ansible_hostname'] }} ceph --cluster {{ cluster | default ('ceph') }} -s
- register: ceph_status
- changed_when: false
- delegate_to: "{{ groups['mons'][0] }}"
- run_once: true
- ignore_errors: true # we skip the error if mon_group_name is different than 'mons'
-
- - name: "show ceph status for cluster {{ cluster | default ('ceph') }}"
- debug:
- msg: "{{ ceph_status.stdout_lines }}"
- delegate_to: "{{ groups['mons'][0] }}"
- run_once: true
- when: not ceph_status.failed