2014-04-11 22:34:33 +08:00
|
|
|
---
|
|
|
|
# This playbook purges Ceph
|
|
|
|
# It removes: packages, configuration files and ALL THE DATA
|
2016-03-24 19:28:01 +08:00
|
|
|
#
|
|
|
|
# Use it like this:
|
|
|
|
# ansible-playbook purge-cluster.yml
|
|
|
|
# Prompts for confirmation to purge, defaults to no and
|
|
|
|
# doesn't purge the cluster. yes purges the cluster.
|
|
|
|
#
|
|
|
|
# ansible-playbook -e ireallymeanit=yes|no purge-cluster.yml
|
|
|
|
# Overrides the prompt using -e option. Can be used in
|
|
|
|
# automation scripts to avoid interactive prompt.
|
|
|
|
|
|
|
|
- name: confirm whether user really meant to purge the cluster
|
|
|
|
hosts: localhost
|
2016-10-06 12:32:38 +08:00
|
|
|
gather_facts: false
|
2016-03-24 19:28:01 +08:00
|
|
|
vars_prompt:
|
|
|
|
- name: ireallymeanit
|
|
|
|
prompt: Are you sure you want to purge the cluster?
|
|
|
|
default: 'no'
|
|
|
|
private: no
|
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: exit playbook, if user did not mean to purge cluster
|
|
|
|
fail:
|
|
|
|
msg: >
|
|
|
|
"Exiting purge-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'
|
2014-04-11 22:34:33 +08:00
|
|
|
|
2016-02-10 20:13:39 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: gather facts on all hosts
|
2016-10-06 12:32:38 +08:00
|
|
|
hosts:
|
2021-07-13 23:11:22 +08:00
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- nfss
|
|
|
|
- clients
|
|
|
|
- mgrs
|
|
|
|
- monitoring
|
2016-10-06 12:32:38 +08:00
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- debug:
|
|
|
|
msg: "gather facts on all Ceph hosts for following reference"
|
|
|
|
|
2016-02-10 20:13:39 +08:00
|
|
|
|
2019-06-21 22:10:16 +08:00
|
|
|
- name: check there's no ceph kernel threads present
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: clients
|
2019-06-21 22:10:16 +08:00
|
|
|
become: true
|
2021-07-13 23:11:22 +08:00
|
|
|
gather_facts: false
|
2019-06-21 22:10:16 +08:00
|
|
|
any_errors_fatal: true
|
|
|
|
tasks:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
|
|
|
|
|
|
|
- block:
|
|
|
|
- name: get nfs nodes ansible facts
|
|
|
|
setup:
|
2020-06-30 22:13:42 +08:00
|
|
|
gather_subset:
|
|
|
|
- 'all'
|
|
|
|
- '!facter'
|
|
|
|
- '!ohai'
|
2019-06-21 22:10:16 +08:00
|
|
|
delegate_to: "{{ item }}"
|
|
|
|
delegate_facts: True
|
|
|
|
with_items: "{{ groups[nfs_group_name] }}"
|
|
|
|
run_once: true
|
|
|
|
|
|
|
|
- name: get all nfs-ganesha mount points
|
2021-03-03 22:43:50 +08:00
|
|
|
command: grep "{{ hostvars[item]['ansible_facts']['all_ipv4_addresses'] | ips_in_ranges(public_network.split(',')) | first }}" /proc/mounts
|
2019-06-21 22:10:16 +08:00
|
|
|
register: nfs_ganesha_mount_points
|
|
|
|
failed_when: false
|
|
|
|
with_items: "{{ groups[nfs_group_name] }}"
|
|
|
|
|
|
|
|
- name: ensure nfs-ganesha mountpoint(s) are unmounted
|
|
|
|
mount:
|
|
|
|
path: "{{ item.split(' ')[1] }}"
|
|
|
|
state: unmounted
|
|
|
|
with_items:
|
|
|
|
- "{{ nfs_ganesha_mount_points.results | map(attribute='stdout_lines') | list }}"
|
|
|
|
when: item | length > 0
|
|
|
|
when: groups[nfs_group_name] | default([]) | length > 0
|
|
|
|
|
|
|
|
- name: ensure cephfs mountpoint(s) are unmounted
|
|
|
|
command: umount -a -t ceph
|
2020-10-02 18:55:53 +08:00
|
|
|
changed_when: false
|
2019-06-21 22:10:16 +08:00
|
|
|
|
2020-08-04 23:29:41 +08:00
|
|
|
- name: find mapped rbd ids
|
|
|
|
find:
|
|
|
|
paths: /sys/bus/rbd/devices
|
|
|
|
file_type: any
|
|
|
|
register: rbd_mapped_ids
|
|
|
|
|
|
|
|
- name: use sysfs to unmap rbd devices
|
|
|
|
shell: "echo {{ item.path | basename }} > /sys/bus/rbd/remove_single_major"
|
2020-10-02 18:55:53 +08:00
|
|
|
changed_when: false
|
2020-08-04 23:29:41 +08:00
|
|
|
with_items: "{{ rbd_mapped_ids.files }}"
|
2019-06-21 22:10:16 +08:00
|
|
|
|
|
|
|
- name: unload ceph kernel modules
|
|
|
|
modprobe:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- rbd
|
|
|
|
- ceph
|
|
|
|
- libceph
|
|
|
|
|
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: purge ceph nfs cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: nfss
|
2019-06-21 22:10:16 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-14 00:48:42 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop ceph nfss with systemd
|
|
|
|
service:
|
2021-07-14 00:48:42 +08:00
|
|
|
name: "{{ 'ceph-nfs@' + ansible_facts['hostname'] if containerized_deployment | bool else 'nfs-ganesha' }}"
|
2021-07-13 20:26:40 +08:00
|
|
|
state: stopped
|
|
|
|
failed_when: false
|
2021-07-14 00:48:42 +08:00
|
|
|
|
|
|
|
- name: remove ceph nfs directories for "{{ ansible_facts['hostname'] }}"
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /etc/ganesha
|
|
|
|
- /var/lib/nfs/ganesha
|
|
|
|
- /var/run/ganesha
|
|
|
|
- /etc/systemd/system/ceph-nfs@.service
|
2019-06-21 22:10:16 +08:00
|
|
|
|
2018-12-06 02:59:47 +08:00
|
|
|
|
|
|
|
- name: purge node-exporter
|
|
|
|
hosts:
|
2021-07-13 23:11:22 +08:00
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- nfss
|
2018-12-06 02:59:47 +08:00
|
|
|
- clients
|
2021-07-13 23:11:22 +08:00
|
|
|
- mgrs
|
|
|
|
- monitoring
|
2018-12-06 02:59:47 +08:00
|
|
|
- iscsigws
|
|
|
|
become: true
|
|
|
|
tasks:
|
2019-12-04 23:10:08 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
2018-12-06 02:59:47 +08:00
|
|
|
|
2020-01-05 15:31:46 +08:00
|
|
|
- block:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
tasks_from: container_binary
|
|
|
|
|
|
|
|
- name: disable node_exporter service
|
|
|
|
service:
|
|
|
|
name: node_exporter
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
|
|
|
|
|
|
|
- name: remove node_exporter service file
|
|
|
|
file:
|
|
|
|
name: /etc/systemd/system/node_exporter.service
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: remove node-exporter image
|
|
|
|
command: "{{ container_binary }} rmi {{ node_exporter_container_image }}"
|
|
|
|
failed_when: false
|
|
|
|
tags:
|
|
|
|
- remove_img
|
|
|
|
when: dashboard_enabled | bool
|
2018-12-06 02:59:47 +08:00
|
|
|
|
|
|
|
|
2020-07-25 06:05:41 +08:00
|
|
|
- name: purge ceph monitoring
|
|
|
|
hosts: monitoring
|
2018-12-06 02:59:47 +08:00
|
|
|
become: true
|
|
|
|
vars:
|
|
|
|
grafana_services:
|
|
|
|
- grafana-server
|
|
|
|
- prometheus
|
|
|
|
- alertmanager
|
|
|
|
tasks:
|
2019-12-04 23:10:08 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
2018-12-06 02:59:47 +08:00
|
|
|
|
2020-01-05 15:31:46 +08:00
|
|
|
- block:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
tasks_from: container_binary
|
|
|
|
|
|
|
|
- name: stop services
|
|
|
|
service:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
with_items: "{{ grafana_services }}"
|
|
|
|
failed_when: false
|
2018-12-06 02:59:47 +08:00
|
|
|
|
2020-01-05 15:31:46 +08:00
|
|
|
- name: remove service files
|
|
|
|
file:
|
|
|
|
name: "/etc/systemd/system/{{ item }}.service"
|
|
|
|
state: absent
|
|
|
|
with_items: "{{ grafana_services }}"
|
|
|
|
failed_when: false
|
|
|
|
|
|
|
|
- name: remove ceph dashboard container images
|
|
|
|
command: "{{ container_binary }} rmi {{ item }}"
|
|
|
|
with_items:
|
|
|
|
- "{{ prometheus_container_image }}"
|
|
|
|
- "{{ grafana_container_image }}"
|
|
|
|
- "{{ alertmanager_container_image }}"
|
|
|
|
failed_when: false
|
|
|
|
tags:
|
|
|
|
- remove_img
|
|
|
|
|
|
|
|
- name: remove data
|
|
|
|
file:
|
|
|
|
name: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /etc/grafana/dashboards
|
|
|
|
- /etc/grafana/grafana.ini
|
|
|
|
- /etc/grafana/provisioning
|
|
|
|
- /var/lib/grafana
|
|
|
|
- /etc/alertmanager
|
|
|
|
- /var/lib/alertmanager
|
|
|
|
- /var/lib/prometheus
|
|
|
|
- /etc/prometheus
|
|
|
|
failed_when: false
|
|
|
|
when: dashboard_enabled | bool
|
2018-12-06 02:59:47 +08:00
|
|
|
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
- name: purge ceph mds cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: mdss
|
2016-10-06 12:32:38 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
2015-10-21 06:32:42 +08:00
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop ceph mdss with systemd
|
|
|
|
service:
|
|
|
|
name: ceph-mds@{{ ansible_facts['hostname'] }}
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
2015-10-21 06:32:42 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove ceph mds service
|
|
|
|
file:
|
2021-08-10 21:21:19 +08:00
|
|
|
path: /etc/systemd/system/ceph-mds{{ item }}
|
2021-07-14 00:48:42 +08:00
|
|
|
state: absent
|
2021-08-10 21:21:19 +08:00
|
|
|
loop:
|
|
|
|
- '@.service'
|
|
|
|
- '.target'
|
2021-07-14 00:48:42 +08:00
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2017-09-24 00:02:49 +08:00
|
|
|
- name: purge ceph mgr cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: mgrs
|
2017-09-24 00:02:49 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop ceph mgrs with systemd
|
|
|
|
service:
|
|
|
|
name: ceph-mgr@{{ ansible_facts['hostname'] }}
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
|
|
|
when: ansible_facts['service_mgr'] == 'systemd'
|
2017-09-24 00:02:49 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove ceph mgr service
|
|
|
|
file:
|
2021-08-10 21:21:19 +08:00
|
|
|
path: /etc/systemd/system/ceph-mgr{{ item }}
|
2021-07-14 00:48:42 +08:00
|
|
|
state: absent
|
2021-08-10 21:21:19 +08:00
|
|
|
loop:
|
|
|
|
- '@.service'
|
|
|
|
- '.target'
|
2017-09-24 00:02:49 +08:00
|
|
|
|
2019-03-01 15:51:43 +08:00
|
|
|
- name: purge rgwloadbalancer cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: rgwloadbalancers
|
2019-03-01 15:51:43 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop rgwloadbalancer services
|
|
|
|
service:
|
|
|
|
name: ['keepalived', 'haproxy']
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
2019-03-01 15:51:43 +08:00
|
|
|
|
2018-12-04 05:58:19 +08:00
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
- name: purge ceph rgw cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: rgws
|
2016-10-06 12:32:38 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
2020-01-31 23:42:10 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2020-01-31 23:42:10 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
tasks_from: set_radosgw_address
|
|
|
|
|
|
|
|
- name: stop ceph rgws with systemd
|
|
|
|
service:
|
2021-03-03 22:43:50 +08:00
|
|
|
name: "ceph-radosgw@rgw.{{ ansible_facts['hostname'] }}.{{ item.instance_name }}"
|
2020-01-31 23:42:10 +08:00
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
|
|
|
with_items: "{{ rgw_instances }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-08-10 21:21:19 +08:00
|
|
|
- name: remove ceph rgw service
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/ceph-radosgw{{ item }}
|
|
|
|
state: absent
|
|
|
|
loop:
|
|
|
|
- '@.service'
|
|
|
|
- '.target'
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
- name: purge ceph rbd-mirror cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: rbdmirrors
|
2016-10-06 12:32:38 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop ceph rbd mirror with systemd
|
|
|
|
service:
|
|
|
|
name: "ceph-rbd-mirror@rbd-mirror.{{ ansible_facts['hostname'] }}"
|
|
|
|
state: stopped
|
2021-07-14 00:48:42 +08:00
|
|
|
enabled: no
|
2021-07-13 20:26:40 +08:00
|
|
|
failed_when: false
|
2014-08-14 20:08:52 +08:00
|
|
|
|
2021-08-10 21:21:19 +08:00
|
|
|
- name: remove ceph rbd-mirror service
|
|
|
|
file:
|
|
|
|
path: /etc/systemd/system/ceph-rbd-mirror{{ item }}
|
|
|
|
state: absent
|
|
|
|
loop:
|
|
|
|
- '@.service'
|
|
|
|
- '.target'
|
|
|
|
|
2014-04-11 22:34:33 +08:00
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
- name: purge ceph osd cluster
|
|
|
|
vars:
|
2017-10-26 20:18:38 +08:00
|
|
|
reboot_osd_node: False
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: osds
|
2021-07-13 20:26:40 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
handlers:
|
|
|
|
- name: restart machine
|
|
|
|
shell: sleep 2 && shutdown -r now "Ansible updates triggered"
|
|
|
|
async: 1
|
|
|
|
poll: 0
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: wait for server to boot
|
|
|
|
become: false
|
|
|
|
wait_for:
|
|
|
|
port: 22
|
|
|
|
host: "{{ hostvars[inventory_hostname]['ansible_facts']['default_ipv4']['address'] }}"
|
|
|
|
state: started
|
|
|
|
delay: 10
|
|
|
|
timeout: 500
|
|
|
|
delegate_to: localhost
|
|
|
|
|
|
|
|
- name: remove data
|
|
|
|
shell: rm -rf /var/lib/ceph/* # noqa 302
|
|
|
|
tasks:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: default lvm_volumes if not defined
|
|
|
|
set_fact:
|
|
|
|
lvm_volumes: []
|
|
|
|
when: lvm_volumes is not defined
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get osd numbers
|
|
|
|
shell: if [ -d /var/lib/ceph/osd ] ; then ls /var/lib/ceph/osd | sed 's/.*-//' ; fi # noqa 306
|
|
|
|
register: osd_ids
|
|
|
|
changed_when: false
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: stop ceph-osd
|
2021-07-13 20:26:40 +08:00
|
|
|
service:
|
|
|
|
name: ceph-osd@{{ item }}
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
with_items: "{{ osd_ids.stdout_lines }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: remove ceph udev rules
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /usr/lib/udev/rules.d/95-ceph-osd.rules
|
|
|
|
- /usr/lib/udev/rules.d/60-ceph-by-parttypeuuid.rules
|
2021-07-14 00:48:42 +08:00
|
|
|
when: not containerized_deployment | bool
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
# 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 # noqa 306
|
|
|
|
register: encrypted_ceph_partuuid
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: get osd data and lockbox mount points
|
|
|
|
shell: (grep /var/lib/ceph/osd /proc/mounts || echo -n) | awk '{ print $2 }' # noqa 306
|
|
|
|
register: mounted_osd
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: drop all cache
|
|
|
|
shell: "sync && sleep 1 && echo 3 > /proc/sys/vm/drop_caches"
|
|
|
|
changed_when: false
|
|
|
|
|
2021-07-22 05:16:59 +08:00
|
|
|
- name: see if ceph-volume is installed # noqa : 305
|
|
|
|
shell: command -v ceph-volume
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_volume_present
|
|
|
|
when: not containerized_deployment | bool
|
|
|
|
|
|
|
|
- name: zap and destroy osds by osd ids
|
|
|
|
ceph_volume:
|
|
|
|
osd_id: "{{ item | int }}"
|
|
|
|
action: "zap"
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: "{{ ceph_volume_debug }}"
|
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment | bool else None }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
|
|
|
with_items: "{{ osd_ids.stdout_lines }}"
|
|
|
|
when:
|
|
|
|
- osd_auto_discovery | default(False) | bool
|
|
|
|
- (containerized_deployment | bool or ceph_volume_present.rc == 0)
|
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: umount osd data partition
|
|
|
|
mount:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: unmounted
|
|
|
|
with_items: "{{ mounted_osd.stdout_lines }}"
|
|
|
|
|
|
|
|
- name: remove osd mountpoint tree
|
|
|
|
file:
|
|
|
|
path: /var/lib/ceph/osd/
|
|
|
|
state: absent
|
|
|
|
register: remove_osd_mountpoints
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: is reboot needed
|
|
|
|
command: echo requesting reboot
|
2020-10-02 19:43:47 +08:00
|
|
|
delegate_to: localhost
|
2021-07-13 20:26:40 +08:00
|
|
|
become: false
|
|
|
|
notify:
|
|
|
|
- restart machine
|
|
|
|
- wait for server to boot
|
|
|
|
- remove data
|
|
|
|
when:
|
|
|
|
- reboot_osd_node | bool
|
|
|
|
- remove_osd_mountpoints.failed is defined
|
|
|
|
|
|
|
|
- name: wipe table on dm-crypt devices
|
|
|
|
command: dmsetup wipe_table --force "{{ item }}"
|
|
|
|
with_items: "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
|
|
|
when: encrypted_ceph_partuuid.stdout_lines | length > 0
|
|
|
|
|
|
|
|
- name: delete dm-crypt devices if any
|
|
|
|
command: dmsetup remove --retry --force {{ item }}
|
|
|
|
with_items: "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
|
|
|
when: encrypted_ceph_partuuid.stdout_lines | length > 0
|
|
|
|
|
|
|
|
- name: get payload_offset
|
|
|
|
shell: cryptsetup luksDump /dev/disk/by-partuuid/{{ item }} | awk '/Payload offset:/ { print $3 }' # noqa 306
|
|
|
|
register: payload_offset
|
|
|
|
with_items: "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
|
|
|
when: encrypted_ceph_partuuid.stdout_lines | length > 0
|
|
|
|
|
|
|
|
- name: get physical sector size
|
|
|
|
command: blockdev --getpbsz /dev/disk/by-partuuid/{{ item }}
|
|
|
|
changed_when: false
|
|
|
|
with_items: "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
|
|
|
when: encrypted_ceph_partuuid.stdout_lines | length > 0
|
|
|
|
register: phys_sector_size
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: wipe dmcrypt device
|
|
|
|
command: dd if=/dev/zero of=/dev/disk/by-partuuid/{{ item.0 }} bs={{ item.1.stdout }} count={{ item.2.stdout }} oflag=direct
|
|
|
|
changed_when: false
|
|
|
|
with_together:
|
|
|
|
- "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
|
|
|
- "{{ payload_offset.results }}"
|
|
|
|
- "{{ phys_sector_size.results }}"
|
|
|
|
|
|
|
|
- name: get ceph data partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph data"
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_data_partition_to_erase_path
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get ceph lockbox partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph lockbox"
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_lockbox_partition_to_erase_path
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: see if ceph-volume is installed # noqa : 305
|
|
|
|
shell: command -v ceph-volume
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_volume_present
|
2021-07-14 00:48:42 +08:00
|
|
|
when: not containerized_deployment | bool
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
- 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: "{{ ceph_volume_debug }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment | bool else None }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
2021-07-13 20:26:40 +08:00
|
|
|
with_items: "{{ lvm_volumes | default([]) }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
when:
|
|
|
|
- containerized_deployment | bool
|
|
|
|
or ceph_volume_present.rc == 0
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
- name: zap and destroy osds created by ceph-volume with devices
|
|
|
|
ceph_volume:
|
|
|
|
data: "{{ item }}"
|
|
|
|
action: "zap"
|
|
|
|
environment:
|
|
|
|
CEPH_VOLUME_DEBUG: "{{ ceph_volume_debug }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
CEPH_CONTAINER_IMAGE: "{{ ceph_docker_registry + '/' + ceph_docker_image + ':' + ceph_docker_image_tag if containerized_deployment | bool else None }}"
|
|
|
|
CEPH_CONTAINER_BINARY: "{{ container_binary }}"
|
2021-07-13 20:26:40 +08:00
|
|
|
with_items:
|
|
|
|
- "{{ devices | default([]) }}"
|
|
|
|
- "{{ dedicated_devices | default([]) }}"
|
|
|
|
- "{{ bluestore_wal_devices | default([]) }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
when:
|
|
|
|
- containerized_deployment | bool
|
|
|
|
or ceph_volume_present.rc == 0
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
- name: get ceph block partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block"
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_block_partition_to_erase_path
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get ceph journal partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph journal"
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_journal_partition_to_erase_path
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get ceph db partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block.db"
|
|
|
|
changed_when: false
|
|
|
|
failed_when: false
|
|
|
|
register: ceph_db_partition_to_erase_path
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get ceph wal partitions
|
|
|
|
shell: |
|
|
|
|
blkid -o device -t PARTLABEL="ceph block.wal"
|
|
|
|
changed_when: false
|
|
|
|
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.stdout_lines +
|
|
|
|
ceph_lockbox_partition_to_erase_path.stdout_lines +
|
|
|
|
ceph_block_partition_to_erase_path.stdout_lines +
|
|
|
|
ceph_journal_partition_to_erase_path.stdout_lines +
|
|
|
|
ceph_db_partition_to_erase_path.stdout_lines +
|
|
|
|
ceph_wal_partition_to_erase_path.stdout_lines }}"
|
|
|
|
|
|
|
|
- name: resolve parent device
|
|
|
|
command: lsblk --nodeps -no pkname "{{ item }}"
|
|
|
|
register: tmp_resolved_parent_device
|
|
|
|
changed_when: false
|
|
|
|
with_items: "{{ combined_devices_list }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: set_fact resolved_parent_device
|
|
|
|
set_fact:
|
|
|
|
resolved_parent_device: "{{ tmp_resolved_parent_device.results | map(attribute='stdout') | list | unique }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: wipe partitions
|
|
|
|
shell: |
|
|
|
|
wipefs --all "{{ item }}"
|
|
|
|
dd if=/dev/zero of="{{ item }}" bs=1 count=4096
|
|
|
|
changed_when: false
|
|
|
|
with_items: "{{ combined_devices_list }}"
|
|
|
|
|
|
|
|
- name: check parent device partition
|
|
|
|
parted:
|
|
|
|
device: "/dev/{{ item }}"
|
|
|
|
loop: "{{ resolved_parent_device }}"
|
|
|
|
register: parted_info
|
|
|
|
|
|
|
|
- name: fail if there is a boot partition on the device
|
|
|
|
fail:
|
|
|
|
msg: "{{ item.item }} has a boot partition"
|
|
|
|
loop: "{{ parted_info.results }}"
|
|
|
|
when: "'boot' in (item.partitions | map(attribute='flags') | list | flatten)"
|
|
|
|
|
|
|
|
- name: zap ceph journal/block db/block wal partitions # noqa 306
|
|
|
|
shell: |
|
|
|
|
sgdisk -Z --clear --mbrtogpt -g -- /dev/"{{ item }}"
|
|
|
|
dd if=/dev/zero of=/dev/"{{ item }}" bs=1M count=200
|
|
|
|
parted -s /dev/"{{ item }}" mklabel gpt
|
|
|
|
partprobe /dev/"{{ item }}"
|
|
|
|
udevadm settle --timeout=600
|
|
|
|
with_items: "{{ resolved_parent_device }}"
|
|
|
|
changed_when: false
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove ceph osd service
|
|
|
|
file:
|
2021-08-10 21:21:19 +08:00
|
|
|
path: /etc/systemd/system/ceph-osd{{ item }}
|
2021-07-14 00:48:42 +08:00
|
|
|
state: absent
|
2021-08-10 21:21:19 +08:00
|
|
|
loop:
|
|
|
|
- '@.service'
|
|
|
|
- '.target'
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
- name: purge ceph mon cluster
|
2021-07-13 23:11:22 +08:00
|
|
|
hosts: mons
|
2021-07-13 20:26:40 +08:00
|
|
|
gather_facts: false # already gathered previously
|
|
|
|
become: true
|
2016-10-06 12:32:38 +08:00
|
|
|
tasks:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: stop ceph mons with systemd
|
|
|
|
service:
|
|
|
|
name: "ceph-{{ item }}@{{ ansible_facts['hostname'] }}"
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
|
|
|
with_items:
|
|
|
|
- mon
|
|
|
|
- mgr
|
|
|
|
|
|
|
|
- name: remove monitor store and bootstrap keys
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /var/lib/ceph/mon
|
|
|
|
- /var/lib/ceph/bootstrap-mds
|
|
|
|
- /var/lib/ceph/bootstrap-osd
|
|
|
|
- /var/lib/ceph/bootstrap-rgw
|
|
|
|
- /var/lib/ceph/bootstrap-rbd
|
|
|
|
- /var/lib/ceph/bootstrap-mgr
|
|
|
|
- /var/lib/ceph/tmp
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove ceph mon and mgr service
|
|
|
|
file:
|
2021-08-10 21:21:19 +08:00
|
|
|
path: "/etc/systemd/system/ceph-{{ item.0 }}{{ item.1 }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
state: absent
|
2021-08-10 21:21:19 +08:00
|
|
|
loop: "{{ ['mon', 'mgr'] | product(['@.service', '.target']) | list }}"
|
2021-07-14 00:48:42 +08:00
|
|
|
|
2017-09-14 07:07:04 +08:00
|
|
|
|
2020-07-03 16:21:49 +08:00
|
|
|
- name: purge ceph-crash daemons
|
|
|
|
hosts:
|
2021-07-13 23:11:22 +08:00
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- mgrs
|
2020-07-03 16:21:49 +08:00
|
|
|
gather_facts: false
|
|
|
|
become: true
|
|
|
|
tasks:
|
2021-07-14 00:48:42 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
|
|
|
|
2020-07-03 16:21:49 +08:00
|
|
|
- name: stop ceph-crash service
|
|
|
|
service:
|
2021-07-14 00:48:42 +08:00
|
|
|
name: "{{ 'ceph-crash@' + ansible_facts['hostname'] if containerized_deployment | bool else 'ceph-crash.service' }}"
|
2020-07-03 16:21:49 +08:00
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
failed_when: false
|
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove service file
|
|
|
|
file:
|
|
|
|
name: "/etc/systemd/system/ceph-crash.service"
|
|
|
|
state: absent
|
|
|
|
failed_when: false
|
|
|
|
|
2020-07-03 16:21:49 +08:00
|
|
|
- name: remove /var/lib/ceph/crash
|
|
|
|
file:
|
|
|
|
path: /var/lib/ceph/crash
|
|
|
|
state: absent
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: check container hosts
|
|
|
|
hosts:
|
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- nfss
|
|
|
|
- mgrs
|
|
|
|
become: true
|
|
|
|
tasks:
|
|
|
|
- name: containerized_deployment only
|
|
|
|
when: containerized_deployment | bool
|
|
|
|
block:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
|
|
|
|
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
tasks_from: container_binary
|
|
|
|
|
|
|
|
- name: remove stopped/exited containers
|
|
|
|
command: >
|
|
|
|
{{ container_binary }} container prune -f
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
- name: show container list on all the nodes (should be empty)
|
|
|
|
command: >
|
|
|
|
{{ container_binary }} 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: >
|
|
|
|
{{ container_binary }} 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-10-06 12:32:38 +08:00
|
|
|
- name: final cleanup - check any running ceph, purge ceph packages, purge config and remove data
|
|
|
|
vars:
|
2017-01-27 18:33:37 +08:00
|
|
|
# When set to true both groups of packages are purged.
|
|
|
|
# This can cause problem with qemu-kvm
|
2016-10-06 12:32:38 +08:00
|
|
|
purge_all_packages: true
|
|
|
|
ceph_packages:
|
|
|
|
- ceph
|
2020-01-17 05:58:35 +08:00
|
|
|
- ceph-base
|
2016-10-06 12:32:38 +08:00
|
|
|
- ceph-common
|
|
|
|
- ceph-fuse
|
|
|
|
- ceph-mds
|
2017-09-24 00:02:49 +08:00
|
|
|
- ceph-mgr
|
2020-01-17 05:58:35 +08:00
|
|
|
- ceph-mon
|
|
|
|
- ceph-osd
|
2016-10-06 12:32:38 +08:00
|
|
|
- ceph-release
|
|
|
|
- ceph-radosgw
|
2018-12-06 02:59:47 +08:00
|
|
|
- ceph-grafana-dashboards
|
2020-01-17 05:58:35 +08:00
|
|
|
- rbd-mirror
|
2016-10-06 12:32:38 +08:00
|
|
|
ceph_remaining_packages:
|
2016-12-09 23:42:04 +08:00
|
|
|
- libcephfs2
|
2016-10-06 12:32:38 +08:00
|
|
|
- librados2
|
|
|
|
- libradosstriper1
|
|
|
|
- librbd1
|
2020-01-17 05:58:35 +08:00
|
|
|
- librgw2
|
|
|
|
- python3-ceph-argparse
|
|
|
|
- python3-cephfs
|
|
|
|
- python3-rados
|
|
|
|
- python3-rbd
|
|
|
|
- python3-rgw
|
2019-03-01 15:51:43 +08:00
|
|
|
extra_packages:
|
|
|
|
- keepalived
|
|
|
|
- haproxy
|
2016-10-06 12:32:38 +08:00
|
|
|
hosts:
|
2021-07-13 23:11:22 +08:00
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- nfss
|
|
|
|
- clients
|
|
|
|
- mgrs
|
|
|
|
- monitoring
|
2016-10-06 12:32:38 +08:00
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
handlers:
|
2021-07-13 20:26:40 +08:00
|
|
|
- name: get osd data and lockbox mount points
|
|
|
|
shell: "(grep /var/lib/ceph/osd /proc/mounts || echo -n) | awk '{ print $2 }'"
|
|
|
|
register: mounted_osd
|
|
|
|
changed_when: false
|
|
|
|
listen: "remove data"
|
|
|
|
|
|
|
|
- name: umount osd data partition
|
|
|
|
mount:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: unmounted
|
|
|
|
with_items: "{{ mounted_osd.stdout_lines }}"
|
|
|
|
listen: "remove data"
|
|
|
|
|
|
|
|
- name: remove data
|
|
|
|
shell: rm -rf /var/lib/ceph/* # noqa 302
|
|
|
|
listen: "remove data"
|
2016-10-06 12:32:38 +08:00
|
|
|
tasks:
|
2021-07-14 00:48:42 +08:00
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
2017-01-27 22:40:41 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: non containerized related tasks
|
|
|
|
when: not containerized_deployment | bool
|
|
|
|
block:
|
|
|
|
- name: purge ceph packages with yum
|
|
|
|
yum:
|
|
|
|
name: "{{ ceph_packages }}"
|
|
|
|
state: absent
|
|
|
|
when: ansible_facts['pkg_mgr'] == 'yum'
|
2017-07-25 18:04:57 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge ceph packages with dnf
|
|
|
|
dnf:
|
|
|
|
name: "{{ ceph_packages }}"
|
|
|
|
state: absent
|
|
|
|
when: ansible_facts['pkg_mgr'] == 'dnf'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge ceph packages with apt
|
|
|
|
apt:
|
|
|
|
name: "{{ ceph_packages }}"
|
|
|
|
state: absent
|
|
|
|
purge: true
|
|
|
|
when: ansible_facts['pkg_mgr'] == 'apt'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge remaining ceph packages with yum
|
|
|
|
yum:
|
|
|
|
name: "{{ ceph_remaining_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'yum'
|
|
|
|
- purge_all_packages | bool
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge remaining ceph packages with dnf
|
|
|
|
dnf:
|
|
|
|
name: "{{ ceph_remaining_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'dnf'
|
|
|
|
- purge_all_packages | bool
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge remaining ceph packages with apt
|
|
|
|
apt:
|
|
|
|
name: "{{ ceph_remaining_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'apt'
|
|
|
|
- purge_all_packages | bool
|
2016-10-06 12:32:38 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge extra packages with yum
|
|
|
|
yum:
|
|
|
|
name: "{{ extra_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'yum'
|
|
|
|
- purge_all_packages | bool
|
2017-02-08 04:42:42 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge extra packages with dnf
|
|
|
|
dnf:
|
|
|
|
name: "{{ extra_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'dnf'
|
|
|
|
- purge_all_packages | bool
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge extra packages with apt
|
|
|
|
apt:
|
|
|
|
name: "{{ extra_packages }}"
|
|
|
|
state: absent
|
|
|
|
when:
|
|
|
|
- ansible_facts['pkg_mgr'] == 'apt'
|
|
|
|
- purge_all_packages | bool
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove config and any ceph socket left
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /etc/ceph
|
|
|
|
- /etc/keepalived
|
|
|
|
- /etc/haproxy
|
|
|
|
- /run/ceph
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: remove logs
|
|
|
|
file:
|
|
|
|
path: /var/log/ceph
|
|
|
|
state: absent
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: request data removal
|
|
|
|
command: echo requesting data removal # noqa 301
|
|
|
|
become: false
|
|
|
|
delegate_to: localhost
|
|
|
|
notify: remove data
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge dnf cache
|
|
|
|
command: dnf clean all
|
|
|
|
when: ansible_facts['pkg_mgr'] == 'dnf'
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: clean apt
|
|
|
|
command: apt-get clean # noqa 303
|
|
|
|
when: ansible_facts['pkg_mgr'] == 'apt'
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: purge ceph repo file in /etc/yum.repos.d
|
|
|
|
file:
|
|
|
|
path: '/etc/yum.repos.d/{{ item }}.repo'
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- ceph-dev
|
|
|
|
- ceph_stable
|
|
|
|
when: ansible_facts['os_family'] == 'RedHat'
|
|
|
|
|
|
|
|
- name: check for anything running ceph
|
|
|
|
command: "ps -u ceph -U ceph"
|
|
|
|
register: check_for_running_ceph
|
|
|
|
changed_when: false
|
|
|
|
failed_when: check_for_running_ceph.rc == 0
|
|
|
|
|
|
|
|
- name: find ceph systemd unit files to remove
|
|
|
|
find:
|
|
|
|
paths: "/etc/systemd/system"
|
|
|
|
pattern: "ceph*"
|
|
|
|
recurse: true
|
|
|
|
file_type: any
|
|
|
|
register: systemd_files
|
|
|
|
|
|
|
|
- name: remove ceph systemd unit files
|
|
|
|
file:
|
|
|
|
path: "{{ item.path }}"
|
|
|
|
state: absent
|
|
|
|
with_items: "{{ systemd_files.files }}"
|
|
|
|
when: ansible_facts['service_mgr'] == 'systemd'
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: containerized related tasks
|
|
|
|
when: containerized_deployment | bool
|
|
|
|
block:
|
|
|
|
- name: check if it is Atomic host
|
|
|
|
stat: path=/run/ostree-booted
|
|
|
|
register: stat_ostree
|
2021-07-13 20:26:40 +08:00
|
|
|
|
2021-07-14 00:48:42 +08:00
|
|
|
- name: set fact for using Atomic host
|
|
|
|
set_fact:
|
|
|
|
is_atomic: "{{ stat_ostree.stat.exists }}"
|
|
|
|
|
|
|
|
- import_role:
|
|
|
|
name: ceph-facts
|
|
|
|
tasks_from: container_binary
|
|
|
|
|
|
|
|
- name: remove ceph container image
|
|
|
|
command: "{{ container_binary }} rmi {{ ceph_docker_registry }}/{{ ceph_docker_image }}:{{ ceph_docker_image_tag }}"
|
|
|
|
changed_when: false
|
|
|
|
when:
|
|
|
|
- inventory_hostname not in groups.get(client_group_name, [])
|
|
|
|
or inventory_hostname == groups.get(client_group_name, []) | first
|
|
|
|
tags:
|
|
|
|
- remove_img
|
|
|
|
|
|
|
|
- name: stop docker service
|
|
|
|
service:
|
|
|
|
name: docker
|
|
|
|
state: stopped
|
|
|
|
enabled: no
|
|
|
|
when:
|
|
|
|
- not is_atomic
|
|
|
|
- container_binary == 'docker'
|
|
|
|
ignore_errors: true
|
|
|
|
|
|
|
|
- name: remove docker on debian/ubuntu
|
|
|
|
apt:
|
|
|
|
name: ['docker-ce', 'docker-engine', 'docker.io', 'python-docker', 'python3-docker']
|
|
|
|
state: absent
|
|
|
|
update_cache: yes
|
|
|
|
autoremove: yes
|
|
|
|
when: ansible_facts['os_family'] == 'Debian'
|
|
|
|
|
|
|
|
- name: red hat based systems tasks
|
|
|
|
block:
|
|
|
|
- name: yum related tasks on red hat
|
|
|
|
block:
|
|
|
|
- name: remove packages on redhat
|
|
|
|
yum:
|
|
|
|
name: ['epel-release', 'docker', 'python-docker-py']
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: remove package dependencies on redhat
|
|
|
|
command: yum -y autoremove
|
|
|
|
args:
|
|
|
|
warn: no
|
|
|
|
|
|
|
|
- name: remove package dependencies on redhat again
|
|
|
|
command: yum -y autoremove
|
|
|
|
args:
|
|
|
|
warn: no
|
|
|
|
when:
|
|
|
|
ansible_facts['pkg_mgr'] == "yum"
|
|
|
|
|
|
|
|
- name: dnf related tasks on red hat
|
|
|
|
block:
|
|
|
|
- name: remove docker on redhat
|
|
|
|
dnf:
|
|
|
|
name: ['docker', 'python3-docker']
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
- name: remove package dependencies on redhat
|
|
|
|
command: dnf -y autoremove
|
|
|
|
args:
|
|
|
|
warn: no
|
|
|
|
|
|
|
|
- name: remove package dependencies on redhat again
|
|
|
|
command: dnf -y autoremove
|
|
|
|
args:
|
|
|
|
warn: no
|
|
|
|
when:
|
|
|
|
ansible_facts['pkg_mgr'] == "dnf"
|
|
|
|
when:
|
|
|
|
ansible_facts['os_family'] == 'RedHat' and
|
|
|
|
not is_atomic
|
|
|
|
|
|
|
|
- name: find any service-cid file left
|
|
|
|
find:
|
|
|
|
paths: /run
|
|
|
|
patterns:
|
|
|
|
- "ceph-*.service-cid"
|
|
|
|
- "rbd-target-api.service-cid"
|
|
|
|
- "rbd-target-gw.service-cid"
|
|
|
|
- "tcmu-runner.service-cid"
|
|
|
|
- "node_exporter.service-cid"
|
|
|
|
- "prometheus.service-cid"
|
|
|
|
- "grafana-server.service-cid"
|
|
|
|
- "alertmanager.service-cid"
|
|
|
|
register: service_cid_files
|
|
|
|
|
|
|
|
- name: rm any service-cid file
|
|
|
|
file:
|
|
|
|
path: "{{ item.path }}"
|
|
|
|
state: absent
|
|
|
|
with_items: "{{ service_cid_files.files }}"
|
|
|
|
|
|
|
|
|
|
|
|
- name: purge ceph directories
|
|
|
|
hosts:
|
|
|
|
- mons
|
|
|
|
- osds
|
|
|
|
- mdss
|
|
|
|
- rgws
|
|
|
|
- rbdmirrors
|
|
|
|
- nfss
|
|
|
|
- mgrs
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
become: true
|
|
|
|
tasks:
|
|
|
|
- import_role:
|
|
|
|
name: ceph-defaults
|
|
|
|
|
|
|
|
- name: purge ceph directories - containerized deployments
|
|
|
|
when: containerized_deployment | bool
|
|
|
|
block:
|
|
|
|
- name: purge ceph directories for "{{ ansible_facts['hostname'] }}" and ceph socket
|
|
|
|
file:
|
|
|
|
path: "{{ item }}"
|
|
|
|
state: absent
|
|
|
|
with_items:
|
|
|
|
- /etc/ceph
|
|
|
|
- /var/log/ceph
|
|
|
|
- /run/ceph
|
|
|
|
- "{{ ceph_osd_docker_run_script_path | default('/usr/share') }}/ceph-osd-run.sh"
|
|
|
|
|
|
|
|
- name: remove ceph data
|
|
|
|
shell: rm -rf /var/lib/ceph/* # noqa 302
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
# (todo): remove this when we are able to manage docker
|
|
|
|
# service on atomic host.
|
|
|
|
- name: remove docker data
|
|
|
|
shell: rm -rf /var/lib/docker/* # noqa 302
|
|
|
|
when: not is_atomic | bool
|
2021-07-13 20:26:40 +08:00
|
|
|
|
|
|
|
|
|
|
|
- name: purge fetch directory
|
|
|
|
hosts: localhost
|
|
|
|
gather_facts: false
|
|
|
|
tasks:
|
|
|
|
- name: set fetch_directory value if not set
|
|
|
|
set_fact:
|
|
|
|
fetch_directory: "fetch/"
|
|
|
|
when: fetch_directory is not defined
|
|
|
|
|
|
|
|
- name: purge fetch directory for localhost
|
|
|
|
file:
|
|
|
|
path: "{{ fetch_directory | default('fetch/') }}"
|
|
|
|
state: absent
|