--- # use shell rather than docker module # to ensure osd disk prepare finishes before # starting the next task - name: prepare ceph "{{ osd_objectstore }}" containerized osd disk(s) non-collocated command: | docker run --net=host \ --pid=host \ --privileged=true \ --name=ceph-osd-prepare-{{ ansible_hostname }}-{{ item.1 | regex_replace('/dev/', '') }} \ -v /etc/ceph:/etc/ceph:z \ -v /var/lib/ceph/:/var/lib/ceph/:z \ -v /dev:/dev \ -v /etc/localtime:/etc/localtime:ro \ -e DEBUG=verbose \ -e CLUSTER={{ cluster }} \ -e CEPH_DAEMON=OSD_CEPH_DISK_PREPARE \ -e OSD_DEVICE={{ item.1 }} \ -e OSD_JOURNAL={{ item.2 }} \ {{ docker_env_args }} \ {{ ceph_osd_docker_prepare_env }} \ {{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }} with_together: - "{{ parted_results.results | default([]) }}" - "{{ devices }}" - "{{ dedicated_devices }}" when: - containerized_deployment - osd_objectstore == 'filestore' - item.0.partitions|length == 0 - name: prepare ceph "{{ osd_objectstore }}" containerized osd disk(s) non-collocated with a dedicated device for db and wal command: | docker run --net=host \ --pid=host \ --privileged=true \ --name=ceph-osd-prepare-{{ ansible_hostname }}-{{ item.1 | regex_replace('/dev/', '') }} \ -v /etc/ceph:/etc/ceph:z \ -v /var/lib/ceph/:/var/lib/ceph/:z \ -v /dev:/dev \ -v /etc/localtime:/etc/localtime:ro \ -e DEBUG=verbose \ -e CLUSTER={{ cluster }} \ -e CEPH_DAEMON=OSD_CEPH_DISK_PREPARE \ -e OSD_DEVICE={{ item.1 }} \ -e OSD_BLUESTORE_BLOCK_DB={{ item.2 }} \ -e OSD_BLUESTORE_BLOCK_WAL={{ item.3 }} \ {{ docker_env_args }} \ {{ ceph_osd_docker_prepare_env }} \ {{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }} with_together: - "{{ parted_results.results | default([]) }}" - "{{ devices }}" - "{{ dedicated_devices }}" - "{{ bluestore_wal_devices }}" when: - containerized_deployment - osd_objectstore == 'bluestore' - item.0.partitions|length == 0 - name: prepare ceph "{{ osd_objectstore }}" non-containerized osd disk(s) non-collocated command: "ceph-disk prepare {{ ceph_disk_cli_options }} {{ item.1 }} {{ item.2 }}" with_together: - "{{ parted_results.results | default([]) }}" - "{{ devices }}" - "{{ dedicated_devices }}" changed_when: false when: - osd_objectstore == 'filestore' - not containerized_deployment - item.0.partitions|length == 0 - name: manually prepare ceph "{{ osd_objectstore }}" non-containerized osd disk(s) with a dedicated device for db and wal command: "ceph-disk prepare {{ ceph_disk_cli_options }} --block.db {{ item.1 }} --block.wal {{ item.2 }} {{ item.3 }}" with_together: - "{{ parted_results.results | default([]) }}" - "{{ dedicated_devices }}" - "{{ bluestore_wal_devices }}" - "{{ devices | unique }}" when: - osd_objectstore == 'bluestore' - not containerized_deployment - item.0.partitions|length == 0