2015-10-21 06:28:35 +08:00
|
|
|
---
|
|
|
|
# This playbook purges a containerized Ceph cluster
|
2016-07-15 03:45:56 +08:00
|
|
|
# It removes: packages, containers, configuration files and ALL THE DATA
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: confirm whether user really meant to purge the cluster
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
- localhost
|
|
|
|
|
2016-07-22 13:29:58 +08:00
|
|
|
gather_facts: false
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
vars_prompt:
|
|
|
|
- name: ireallymeanit
|
2016-07-22 13:29:58 +08:00
|
|
|
prompt: >
|
2018-03-27 20:26:12 +08:00
|
|
|
Are you sure you want to purge the cluster?
|
|
|
|
Note that if with_pkg is not set docker packages
|
2016-07-22 13:29:58 +08:00
|
|
|
and more will be uninstalled from non-atomic hosts.
|
|
|
|
Do you want to continue?
|
|
|
|
default: 'no'
|
|
|
|
private: no
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
tasks:
|
|
|
|
- name: exit playbook, if user did not mean to purge cluster
|
|
|
|
fail:
|
|
|
|
msg: >
|
|
|
|
"Exiting purge-docker-cluster playbook, cluster was NOT purged.
|
|
|
|
To purge the cluster, either say 'yes' on the prompt or
|
|
|
|
or use `-e ireallymeanit=yes` on the command line when
|
|
|
|
invoking the playbook"
|
|
|
|
when: ireallymeanit != 'yes'
|
|
|
|
|
2017-06-02 20:42:34 +08:00
|
|
|
- name: set ceph_docker_registry value if not set
|
|
|
|
set_fact:
|
|
|
|
ceph_docker_registry: "docker.io"
|
|
|
|
when: ceph_docker_registry is not defined
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge ceph mds cluster
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ mds_group_name|default('mdss') }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
become: true
|
2015-10-21 06:28:35 +08:00
|
|
|
|
|
|
|
tasks:
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: disable ceph mds service
|
|
|
|
service:
|
|
|
|
name: "ceph-mds@{{ ansible_hostname }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph mds container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2017-02-20 17:03:49 +08:00
|
|
|
name: "ceph-mds-{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph mds service
|
|
|
|
file:
|
2016-08-13 00:47:10 +08:00
|
|
|
path: /etc/systemd/system/ceph-mds@.service
|
|
|
|
state: absent
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
- name: remove ceph mds image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
2018-11-30 00:52:18 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
|
|
|
force: yes
|
|
|
|
tags:
|
|
|
|
remove_img
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: purge ceph iscsigws cluster
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
- "{{ iscsi_gw_group_name|default('iscsigws') }}"
|
|
|
|
- iscsi-gws
|
|
|
|
become: true
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
- name: disable ceph iscsigw services
|
|
|
|
service:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
with_items:
|
|
|
|
- rbd-target-api
|
|
|
|
- rbd-target-gw
|
|
|
|
- tcmu-runner
|
|
|
|
|
|
|
|
- name: remove ceph iscsigw containers
|
|
|
|
docker_container:
|
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
with_items:
|
|
|
|
- rbd-target-api
|
|
|
|
- rbd-target-gw
|
|
|
|
- tcmu-runner
|
|
|
|
|
|
|
|
- name: remove ceph iscsigw systemd unit files
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/{{ item }}.service
|
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
with_items:
|
|
|
|
- rbd-target-api
|
|
|
|
- rbd-target-gw
|
|
|
|
- tcmu-runner
|
|
|
|
|
|
|
|
- name: remove ceph iscsigw image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
2017-06-02 20:42:34 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
2017-02-09 22:16:39 +08:00
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
2017-02-06 21:58:39 +08:00
|
|
|
force: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
tags:
|
|
|
|
remove_img
|
2018-03-29 07:46:54 +08:00
|
|
|
ignore_errors: true
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2017-09-24 00:02:49 +08:00
|
|
|
- name: purge ceph mgr cluster
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
|
|
|
become: true
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
- name: disable ceph mgr service
|
|
|
|
service:
|
|
|
|
name: "ceph-mgr@{{ ansible_hostname }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph mgr container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-09-24 00:02:49 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
name: "ceph-mgr-{{ ansible_hostname }}"
|
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph mgr service
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/ceph-mgr@.service
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: remove ceph mgr image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
|
|
|
repository: "{{ ceph_docker_registry }}"
|
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
|
|
|
force: yes
|
|
|
|
tags:
|
|
|
|
remove_img
|
2018-03-29 07:46:54 +08:00
|
|
|
ignore_errors: true
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge ceph rgw cluster
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ rgw_group_name|default('rgws') }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
tasks:
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2017-07-29 07:00:06 +08:00
|
|
|
# For backward compatibility
|
|
|
|
- name: disable ceph rgw service (old unit name, for backward compatibility)
|
2016-07-15 03:45:56 +08:00
|
|
|
service:
|
|
|
|
name: "ceph-rgw@{{ ansible_hostname }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
2017-07-29 07:00:06 +08:00
|
|
|
- name: disable ceph rgw service (new unit name)
|
|
|
|
service:
|
2017-09-24 10:52:51 +08:00
|
|
|
name: "ceph-radosgw@rgw.{{ ansible_hostname }}"
|
2017-07-29 07:00:06 +08:00
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: remove ceph rgw container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2017-02-20 17:03:49 +08:00
|
|
|
name: "ceph-rgw-{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph rgw service
|
|
|
|
file:
|
2017-07-29 07:00:06 +08:00
|
|
|
path: "{{ item }}"
|
2016-08-13 00:47:10 +08:00
|
|
|
state: absent
|
2017-07-29 07:00:06 +08:00
|
|
|
with_items:
|
|
|
|
# For backward compatibility
|
|
|
|
- /etc/systemd/system/ceph-rgw@.service
|
|
|
|
- /etc/systemd/system/ceph-radosgw@.service
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
- name: remove ceph rgw image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
2017-06-02 20:42:34 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
2017-02-09 22:16:39 +08:00
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
2017-02-06 21:58:39 +08:00
|
|
|
force: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
tags:
|
|
|
|
remove_img
|
2018-03-29 07:46:54 +08:00
|
|
|
ignore_errors: true
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-08-12 09:24:26 +08:00
|
|
|
- name: purge ceph rbd-mirror cluster
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ rbdmirror_group_name|default('rbdmirrors') }}"
|
2016-08-12 09:24:26 +08:00
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
- name: disable ceph rbd-mirror service
|
|
|
|
service:
|
2017-09-25 03:11:04 +08:00
|
|
|
name: "ceph-rbd-mirror@rbd-mirror.{{ ansible_hostname }}"
|
2016-08-12 09:24:26 +08:00
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph rbd-mirror container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2017-02-20 17:03:49 +08:00
|
|
|
name: "ceph-rbd-mirror-{{ ansible_hostname }}"
|
2016-08-12 09:24:26 +08:00
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph rbd-mirror service
|
|
|
|
file:
|
2016-08-13 00:47:10 +08:00
|
|
|
path: /etc/systemd/system/ceph-rbd-mirror@.service
|
|
|
|
state: absent
|
2016-08-12 09:24:26 +08:00
|
|
|
|
|
|
|
- name: remove ceph rbd-mirror image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
2017-06-02 20:42:34 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
2017-02-09 22:16:39 +08:00
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
2017-02-06 21:58:39 +08:00
|
|
|
force: yes
|
2016-08-12 09:24:26 +08:00
|
|
|
tags:
|
|
|
|
remove_img
|
|
|
|
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge ceph nfs cluster
|
2016-04-25 22:40:41 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ nfs_group_name|default('nfss') }}"
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
become: true
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
tasks:
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: disable ceph nfs service
|
|
|
|
service:
|
|
|
|
name: "ceph-nfs@{{ ansible_hostname }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph nfs container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2017-02-20 17:03:49 +08:00
|
|
|
name: "ceph-nfs-{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph nfs service
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/ceph-nfs@.service
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: remove ceph nfs directories for "{{ ansible_hostname }}"
|
2016-04-25 22:40:41 +08:00
|
|
|
file:
|
2016-06-22 00:29:02 +08:00
|
|
|
path: "{{ item }}"
|
2016-04-25 22:40:41 +08:00
|
|
|
state: absent
|
2015-10-21 06:28:35 +08:00
|
|
|
with_items:
|
2016-07-15 03:45:56 +08:00
|
|
|
- /etc/ganesha
|
|
|
|
- /var/lib/nfs/ganesha
|
|
|
|
- /var/run/ganesha
|
|
|
|
|
|
|
|
- name: remove ceph nfs image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
2017-06-02 20:42:34 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
2017-02-09 22:16:39 +08:00
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
2017-02-06 21:58:39 +08:00
|
|
|
force: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
tags:
|
|
|
|
remove_img
|
|
|
|
|
|
|
|
|
|
|
|
- name: purge ceph osd cluster
|
|
|
|
|
|
|
|
hosts:
|
2018-12-05 16:06:53 +08:00
|
|
|
- "{{ osd_group_name | default('osds') }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2018-12-04 16:22:34 +08:00
|
|
|
gather_facts: true
|
2016-07-15 03:45:56 +08:00
|
|
|
become: true
|
|
|
|
|
2018-12-10 22:46:32 +08:00
|
|
|
# This is a tricks so we can access 'ceph-defaults' defaults variables in 'ceph-facts
|
|
|
|
roles:
|
|
|
|
- ceph-defaults
|
|
|
|
|
|
|
|
post_tasks:
|
|
|
|
- name: gather monitors facts
|
|
|
|
setup:
|
|
|
|
delegate_to: "{{ item }}"
|
|
|
|
delegate_facts: True
|
|
|
|
with_items: "{{ groups.get(mon_group_name | default('mons')) }}"
|
|
|
|
|
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
private: false
|
|
|
|
|
|
|
|
- name: get all the running osds
|
|
|
|
shell: |
|
|
|
|
systemctl list-units | grep 'loaded[[:space:]]\+active' | grep -oE "ceph-osd@([0-9]{1,2}|[a-z]+).service"
|
|
|
|
register: osd_units
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: disable ceph osd service
|
|
|
|
service:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
with_items: "{{ osd_units.stdout_lines }}"
|
|
|
|
|
|
|
|
- name: remove osd mountpoint tree
|
|
|
|
file:
|
|
|
|
path: /var/lib/ceph/osd/
|
|
|
|
state: absent
|
|
|
|
register: remove_osd_mountpoints
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: for ceph-disk based deployment
|
|
|
|
block:
|
|
|
|
- name: get prepare container
|
|
|
|
command: "docker ps -a -q --filter='name=ceph-osd-prepare'"
|
|
|
|
register: prepare_containers
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove ceph osd prepare container
|
|
|
|
command: "docker rm -f {{ item }}"
|
|
|
|
with_items: "{{ prepare_containers.stdout_lines }}"
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
# NOTE(leseb): hope someone will find a more elegant way one day...
|
|
|
|
- name: see if encrypted partitions are present
|
|
|
|
shell: |
|
|
|
|
blkid -t TYPE=crypto_LUKS -s PARTLABEL -s PARTUUID | grep "ceph.*." | grep -o PARTUUID.* | cut -d '"' -f 2
|
|
|
|
register: encrypted_ceph_partuuid
|
|
|
|
|
|
|
|
- name: get ceph data partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph data"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_data_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: get ceph lockbox partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph lockbox"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_lockbox_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: get ceph block partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_block_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: get ceph journal partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph journal"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_journal_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: get ceph db partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block.db"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_db_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: get ceph wal partitions
|
|
|
|
command: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block.wal"
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_wal_partition_to_erase_path
|
|
|
|
|
|
|
|
- name: set_fact combined_devices_list
|
|
|
|
set_fact:
|
|
|
|
combined_devices_list: "{{ ceph_data_partition_to_erase_path.get('stdout_lines', []) +
|
|
|
|
ceph_lockbox_partition_to_erase_path.get('stdout_lines', []) +
|
|
|
|
ceph_block_partition_to_erase_path.get('stdout_lines', []) +
|
|
|
|
ceph_journal_partition_to_erase_path.get('stdout_lines', []) +
|
|
|
|
ceph_db_partition_to_erase_path.get('stdout_lines', []) +
|
|
|
|
ceph_wal_partition_to_erase_path.get('stdout_lines', []) }}"
|
|
|
|
|
|
|
|
- name: resolve parent device
|
|
|
|
command: lsblk --nodeps -no pkname "{{ item }}"
|
|
|
|
register: tmp_resolved_parent_device
|
|
|
|
with_items:
|
|
|
|
- "{{ combined_devices_list }}"
|
|
|
|
|
|
|
|
- name: set_fact resolved_parent_device
|
|
|
|
set_fact:
|
|
|
|
resolved_parent_device: "{{ tmp_resolved_parent_device.results | map(attribute='stdout') | list | unique }}"
|
|
|
|
|
|
|
|
- name: zap ceph osd disks
|
|
|
|
shell: |
|
|
|
|
docker run --rm \
|
|
|
|
--privileged=true \
|
|
|
|
--name ceph-osd-zap-{{ ansible_hostname }}-{{ item }} \
|
|
|
|
-v /dev/:/dev/ \
|
|
|
|
-e OSD_DEVICE=/dev/{{ item }} \
|
|
|
|
{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }} \
|
|
|
|
zap_device
|
|
|
|
with_items:
|
|
|
|
- "{{ resolved_parent_device }}"
|
|
|
|
|
|
|
|
- name: wait until the zap containers die
|
|
|
|
shell: |
|
|
|
|
docker ps | grep -sq ceph-osd-zap-{{ ansible_hostname }}
|
|
|
|
register: zap_alive
|
|
|
|
failed_when: false
|
|
|
|
until: zap_alive.rc != 0
|
|
|
|
retries: 5
|
|
|
|
delay: 10
|
|
|
|
|
|
|
|
- name: remove ceph osd zap disk container
|
|
|
|
docker_container:
|
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
name: "ceph-osd-zap-{{ ansible_hostname }}-{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- "{{ resolved_parent_device }}"
|
|
|
|
when:
|
|
|
|
- osd_scenario != "lvm"
|
|
|
|
|
|
|
|
- name: for ceph-volume based deployments
|
|
|
|
block:
|
|
|
|
- name: zap and destroy osds created by ceph-volume with lvm_volumes
|
|
|
|
ceph_volume:
|
|
|
|
data: "{{ item.data }}"
|
|
|
|
data_vg: "{{ item.data_vg|default(omit) }}"
|
|
|
|
journal: "{{ item.journal|default(omit) }}"
|
|
|
|
journal_vg: "{{ item.journal_vg|default(omit) }}"
|
|
|
|
db: "{{ item.db|default(omit) }}"
|
|
|
|
db_vg: "{{ item.db_vg|default(omit) }}"
|
|
|
|
wal: "{{ item.wal|default(omit) }}"
|
|
|
|
wal_vg: "{{ item.wal_vg|default(omit) }}"
|
|
|
|
action: "zap"
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: 1
|
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "docker"
|
|
|
|
with_items: "{{ lvm_volumes }}"
|
2019-04-02 16:43:01 +08:00
|
|
|
when: lvm_volumes | default([]) | length > 0
|
2018-12-10 22:46:32 +08:00
|
|
|
|
|
|
|
- name: zap and destroy osds created by ceph-volume with devices
|
|
|
|
ceph_volume:
|
|
|
|
data: "{{ item }}"
|
|
|
|
action: "zap"
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: 1
|
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "docker"
|
|
|
|
with_items: "{{ devices | default([]) }}"
|
2019-04-02 16:43:01 +08:00
|
|
|
when: devices | default([]) | length > 0
|
2018-12-10 22:46:32 +08:00
|
|
|
when:
|
|
|
|
- osd_scenario == "lvm"
|
|
|
|
|
2019-03-21 01:40:33 +08:00
|
|
|
- name: remove ceph osd service
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/ceph-osd@.service
|
|
|
|
state: absent
|
|
|
|
|
2018-12-10 22:46:32 +08:00
|
|
|
- name: remove ceph osd image
|
|
|
|
docker_image:
|
|
|
|
state: absent
|
|
|
|
repository: "{{ ceph_docker_registry }}"
|
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
|
|
|
force: yes
|
|
|
|
tags:
|
|
|
|
remove_img
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: include vars from group_vars/osds.yml
|
|
|
|
include_vars:
|
|
|
|
file: "{{ item }}"
|
|
|
|
with_first_found:
|
|
|
|
- files:
|
|
|
|
- "{{ playbook_dir }}/group_vars/osds"
|
|
|
|
- "{{ playbook_dir }}/group_vars/osds.yml"
|
|
|
|
skip: true
|
|
|
|
|
|
|
|
- name: find all osd_disk_prepare logs
|
|
|
|
find:
|
|
|
|
paths: "{{ ceph_osd_docker_run_script_path | default('/usr/share') }}"
|
|
|
|
pattern: "ceph-osd-prepare-*.log"
|
|
|
|
register: osd_disk_prepare_logs
|
|
|
|
|
|
|
|
- name: ensure all osd_disk_prepare logs are removed
|
|
|
|
file:
|
|
|
|
path: "{{ item.path }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- "{{ osd_disk_prepare_logs.files }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
- name: purge ceph mon cluster
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ mon_group_name|default('mons') }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
tasks:
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2018-12-04 05:46:52 +08:00
|
|
|
# since mgr are now collocated with mons by default
|
|
|
|
- name: disable ceph mon and mgr service
|
2016-07-15 03:45:56 +08:00
|
|
|
service:
|
2018-12-04 05:46:52 +08:00
|
|
|
name: "{{ item }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
ignore_errors: true
|
2018-12-04 05:46:52 +08:00
|
|
|
with_items:
|
|
|
|
- "ceph-mgr@{{ ansible_hostname }}"
|
|
|
|
- "ceph-mon@{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2018-12-04 05:46:52 +08:00
|
|
|
- name: remove ceph mon and mgr container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2018-12-04 05:46:52 +08:00
|
|
|
name: "{{ item }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|
|
|
|
ignore_errors: true
|
2018-12-04 05:46:52 +08:00
|
|
|
with_items:
|
|
|
|
- "ceph-mon-{{ ansible_hostname }}"
|
|
|
|
- "ceph-mgr-{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
- name: remove restapi container
|
2018-07-09 21:50:52 +08:00
|
|
|
docker_container:
|
2017-06-02 20:42:34 +08:00
|
|
|
image: "{{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
2017-02-20 17:03:49 +08:00
|
|
|
name: "ceph-restapi-{{ ansible_hostname }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|
2016-08-13 00:47:10 +08:00
|
|
|
ignore_errors: true
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
- name: remove ceph mon service
|
|
|
|
file:
|
2018-12-04 05:46:52 +08:00
|
|
|
path: "/etc/systemd/system/ceph-{{ item }}@.service"
|
2016-08-13 00:47:10 +08:00
|
|
|
state: absent
|
2018-12-04 05:46:52 +08:00
|
|
|
with_items:
|
|
|
|
- mon
|
|
|
|
- mgr
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2018-12-04 05:46:52 +08:00
|
|
|
- name: remove ceph mon and mgr image
|
2016-07-15 03:45:56 +08:00
|
|
|
docker_image:
|
|
|
|
state: absent
|
2017-06-02 20:42:34 +08:00
|
|
|
repository: "{{ ceph_docker_registry }}"
|
2017-02-09 22:16:39 +08:00
|
|
|
name: "{{ ceph_docker_image }}"
|
|
|
|
tag: "{{ ceph_docker_image_tag }}"
|
2017-02-06 21:58:39 +08:00
|
|
|
force: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
tags:
|
|
|
|
remove_img
|
2018-03-29 07:46:54 +08:00
|
|
|
ignore_errors: true
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2018-03-01 01:53:57 +08:00
|
|
|
- name: remove ceph aliases
|
|
|
|
file:
|
|
|
|
path: /etc/profile.d/ceph-aliases.sh
|
|
|
|
state: absent
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2018-12-03 23:46:38 +08:00
|
|
|
- name: check container hosts
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
- "{{ mon_group_name|default('mons') }}"
|
|
|
|
- "{{ osd_group_name|default('osds') }}"
|
|
|
|
- "{{ mds_group_name|default('mdss') }}"
|
|
|
|
- "{{ rgw_group_name|default('rgws') }}"
|
|
|
|
- "{{ rbdmirror_group_name|default('rbdmirrors') }}"
|
|
|
|
- "{{ nfs_group_name|default('nfss') }}"
|
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
|
|
|
|
2018-12-04 16:22:34 +08:00
|
|
|
gather_facts: true
|
2018-12-03 23:46:38 +08:00
|
|
|
become: true
|
|
|
|
|
2018-12-10 22:46:32 +08:00
|
|
|
# This is a tricks so we can access 'ceph-defaults' defaults variables in 'ceph-facts'
|
|
|
|
roles:
|
|
|
|
- ceph-defaults
|
2018-12-03 23:46:38 +08:00
|
|
|
|
2018-12-10 22:46:32 +08:00
|
|
|
post_tasks:
|
2018-12-12 23:34:14 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
private: false
|
|
|
|
|
2018-12-03 23:46:38 +08:00
|
|
|
- name: show container list on all the nodes (should be empty)
|
|
|
|
command: >
|
|
|
|
docker ps --filter='name=ceph' -a -q
|
|
|
|
register: containers_list
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: show container images on all the nodes (should be empty if tags was passed remove_img)
|
|
|
|
command: >
|
|
|
|
docker images
|
|
|
|
register: images_list
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: fail if container are still present
|
|
|
|
fail:
|
|
|
|
msg: "It looks like container are still present."
|
|
|
|
when: containers_list.stdout_lines|length > 0
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: remove installed packages
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ mon_group_name|default('mons') }}"
|
|
|
|
- "{{ osd_group_name|default('osds') }}"
|
|
|
|
- "{{ mds_group_name|default('mdss') }}"
|
|
|
|
- "{{ rgw_group_name|default('rgws') }}"
|
|
|
|
- "{{ rbdmirror_group_name|default('rbdmirrors') }}"
|
|
|
|
- "{{ nfs_group_name|default('nfss') }}"
|
2017-09-24 00:02:49 +08:00
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
tags:
|
|
|
|
with_pkg
|
|
|
|
|
|
|
|
tasks:
|
2016-07-22 13:29:58 +08:00
|
|
|
- name: check if it is Atomic host
|
|
|
|
stat: path=/run/ostree-booted
|
|
|
|
register: stat_ostree
|
|
|
|
|
|
|
|
- name: set fact for using Atomic host
|
|
|
|
set_fact:
|
|
|
|
is_atomic: "{{ stat_ostree.stat.exists }}"
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: stop docker service
|
|
|
|
service:
|
|
|
|
name: docker
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
when: not is_atomic
|
2018-03-29 07:46:54 +08:00
|
|
|
ignore_errors: true
|
2016-07-15 03:45:56 +08:00
|
|
|
|
2017-05-31 04:06:46 +08:00
|
|
|
- name: remove docker-py on Debian
|
2016-07-28 22:55:37 +08:00
|
|
|
pip:
|
|
|
|
name: docker-py
|
|
|
|
state: absent
|
|
|
|
when:
|
2017-05-31 04:06:46 +08:00
|
|
|
- ansible_distribution == 'Debian'
|
2016-07-28 22:55:37 +08:00
|
|
|
|
2017-05-31 04:06:46 +08:00
|
|
|
- name: remove six on Debian
|
2016-07-28 22:55:37 +08:00
|
|
|
pip:
|
|
|
|
name: six
|
|
|
|
state: absent
|
2017-05-31 04:06:46 +08:00
|
|
|
when:
|
|
|
|
- ansible_distribution == 'Debian'
|
2016-07-28 22:55:37 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: remove pip and docker on ubuntu
|
|
|
|
apt:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
update_cache: yes
|
2016-07-28 22:55:37 +08:00
|
|
|
autoremove: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
with_items:
|
|
|
|
- python-pip
|
|
|
|
- docker
|
|
|
|
- docker.io
|
|
|
|
when: ansible_distribution == 'Ubuntu'
|
|
|
|
|
|
|
|
- name: remove pip and docker on debian
|
|
|
|
apt:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
update_cache: yes
|
2016-07-28 22:55:37 +08:00
|
|
|
autoremove: yes
|
2016-07-15 03:45:56 +08:00
|
|
|
with_items:
|
|
|
|
- python-pip
|
|
|
|
- docker-engine
|
|
|
|
when: ansible_distribution == 'Debian'
|
|
|
|
|
|
|
|
- name: remove epel-release on redhat
|
|
|
|
yum:
|
|
|
|
name: epel-release
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
- name: remove pip on redhat
|
|
|
|
yum:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- python-pip
|
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "yum" and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
- name: remove docker-engine on redhat
|
|
|
|
yum:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- docker-engine
|
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "yum" and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
# for CentOS
|
|
|
|
- name: remove docker on redhat
|
|
|
|
yum:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- docker
|
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "yum" and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
- name: remove pip and docker on redhat
|
|
|
|
dnf:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- python-pip
|
|
|
|
- docker-engine
|
|
|
|
- docker
|
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "dnf" and
|
|
|
|
not is_atomic
|
|
|
|
|
2016-07-28 22:55:37 +08:00
|
|
|
- name: remove package dependencies on redhat
|
|
|
|
command: yum -y autoremove
|
2017-10-12 21:38:01 +08:00
|
|
|
args:
|
|
|
|
warn: no
|
2016-07-28 22:55:37 +08:00
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "yum" and
|
|
|
|
not is_atomic
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-28 22:55:37 +08:00
|
|
|
- name: remove package dependencies on redhat again
|
|
|
|
command: yum -y autoremove
|
2017-10-12 21:38:01 +08:00
|
|
|
args:
|
|
|
|
warn: no
|
2016-07-15 03:45:56 +08:00
|
|
|
when:
|
2016-07-28 22:55:37 +08:00
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "yum" and
|
2016-07-15 03:45:56 +08:00
|
|
|
not is_atomic
|
|
|
|
|
2016-07-28 22:55:37 +08:00
|
|
|
- name: remove package dependencies on redhat
|
|
|
|
command: dnf -y autoremove
|
2017-10-12 21:38:01 +08:00
|
|
|
args:
|
|
|
|
warn: no
|
2016-07-15 03:45:56 +08:00
|
|
|
when:
|
2016-07-28 22:55:37 +08:00
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "dnf" and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
- name: remove package dependencies on redhat again
|
|
|
|
command: dnf -y autoremove
|
2017-10-12 21:38:01 +08:00
|
|
|
args:
|
|
|
|
warn: no
|
2016-07-28 22:55:37 +08:00
|
|
|
when:
|
|
|
|
ansible_os_family == 'RedHat' and
|
|
|
|
ansible_pkg_mgr == "dnf" and
|
2016-07-15 03:45:56 +08:00
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
|
|
|
|
- name: purge ceph directories
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 03:23:40 +08:00
|
|
|
- "{{ mon_group_name|default('mons') }}"
|
|
|
|
- "{{ osd_group_name|default('osds') }}"
|
|
|
|
- "{{ mds_group_name|default('mdss') }}"
|
|
|
|
- "{{ rgw_group_name|default('rgws') }}"
|
|
|
|
- "{{ rbdmirror_group_name|default('rbdmirrors') }}"
|
|
|
|
- "{{ nfs_group_name|default('nfss') }}"
|
2017-09-24 00:02:49 +08:00
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
2016-07-22 13:29:58 +08:00
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
2016-07-15 03:45:56 +08:00
|
|
|
|
|
|
|
become: true
|
2015-10-21 06:28:35 +08:00
|
|
|
|
|
|
|
tasks:
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge ceph directories for "{{ ansible_hostname }}"
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /etc/ceph
|
|
|
|
- /var/log/ceph
|
|
|
|
|
2018-08-28 02:02:59 +08:00
|
|
|
- name: remove data
|
2018-09-27 17:33:51 +08:00
|
|
|
shell: rm -rf /var/lib/ceph/*
|
2018-08-28 02:02:59 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge fetch directory
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
hosts:
|
|
|
|
- localhost
|
2015-10-21 06:28:35 +08:00
|
|
|
|
2016-07-22 13:29:58 +08:00
|
|
|
gather_facts: false
|
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
tasks:
|
2017-03-08 03:45:22 +08:00
|
|
|
|
|
|
|
- name: set fetch_directory value if not set
|
|
|
|
set_fact:
|
|
|
|
fetch_directory: "fetch/"
|
|
|
|
when: fetch_directory is not defined
|
2016-07-22 13:29:58 +08:00
|
|
|
|
2016-07-15 03:45:56 +08:00
|
|
|
- name: purge fetch directory for localhost
|
|
|
|
file:
|
2018-03-29 07:46:54 +08:00
|
|
|
path: "{{ fetch_directory }}/"
|
2016-07-15 03:45:56 +08:00
|
|
|
state: absent
|