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:
|
2016-03-29 21:37:31 +08:00
|
|
|
|
- name: exit playbook, if user did not mean to purge cluster
|
2016-03-24 19:28:01 +08:00
|
|
|
|
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
|
|
|
|
|
2017-02-08 01:57:38 +08:00
|
|
|
|
- name: gather facts on all hosts
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +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') }}"
|
|
|
|
|
- "{{ client_group_name|default('clients') }}"
|
2017-09-24 00:02:49 +08:00
|
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
become: true
|
2016-02-29 20:19:56 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
tasks:
|
2017-02-08 01:57:38 +08:00
|
|
|
|
- debug: msg="gather facts on all Ceph hosts for following reference"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: purge ceph mds cluster
|
2016-03-29 21:37:31 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
vars:
|
|
|
|
|
mds_group_name: mdss
|
2014-04-11 22:34:33 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ mds_group_name|default('mdss') }}"
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
gather_facts: false # Already gathered previously
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
become: true
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
2015-10-21 06:32:42 +08:00
|
|
|
|
tasks:
|
2016-04-07 03:58:17 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph mdss with systemd
|
2016-02-10 20:13:39 +08:00
|
|
|
|
service:
|
2016-10-06 12:32:38 +08:00
|
|
|
|
name: ceph-mds@{{ ansible_hostname }}
|
2016-02-10 20:13:39 +08:00
|
|
|
|
state: stopped
|
|
|
|
|
enabled: no
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2015-10-21 06:32:42 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph mdss
|
|
|
|
|
shell: "service ceph status mds ; if [ $? == 0 ] ; then service ceph stop mds ; else echo ; fi"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'sysvinit'
|
2015-10-21 06:32:42 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph mdss on ubuntu
|
|
|
|
|
command: initctl stop ceph-mds cluster={{ cluster }} id={{ ansible_hostname }}
|
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
2017-09-24 00:02:49 +08:00
|
|
|
|
- name: purge ceph mgr cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
|
|
|
|
mgr_group_name: mgrs
|
|
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
|
|
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
|
|
- name: stop ceph mgrs with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: ceph-mgr@{{ ansible_hostname}}
|
|
|
|
|
state: stopped
|
|
|
|
|
enabled: no
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-09-24 00:02:49 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: purge ceph rgw cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
|
|
|
|
rgw_group_name: rgws
|
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ rgw_group_name|default('rgws') }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
2016-03-29 07:53:01 +08:00
|
|
|
|
- name: stop ceph rgws with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: ceph-radosgw@rgw.{{ ansible_hostname }}
|
|
|
|
|
state: stopped
|
2016-10-06 12:32:38 +08:00
|
|
|
|
enabled: no
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2016-03-29 07:53:01 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph rgws
|
|
|
|
|
shell: "service ceph-radosgw status ; if [ $? == 0 ] ; then service ceph-radosgw stop ; else echo ; fi"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'sysvinit'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: stop ceph rgws on ubuntu
|
|
|
|
|
command: initctl stop radosgw cluster={{ cluster }} id={{ ansible_hostname }}
|
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- name: purge ceph rbd-mirror cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
2016-11-01 20:09:44 +08:00
|
|
|
|
rbdmirror_group_name: rbd-mirrors
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ rbdmirror_group_name|default('rbdmirrors') }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
2016-04-04 06:35:09 +08:00
|
|
|
|
- name: stop ceph rbd mirror with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: ceph-rbd-mirror@admin.service
|
|
|
|
|
state: stopped
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2016-04-07 03:58:17 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph rbd mirror on ubuntu
|
2016-11-01 20:29:21 +08:00
|
|
|
|
command: initctl stop ceph-rbd-mirror cluster={{ cluster }} id=admin
|
2016-10-06 12:32:38 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2014-08-14 20:08:52 +08:00
|
|
|
|
|
2014-04-11 22:34:33 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: purge ceph nfs cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
|
|
|
|
nfs_group_name: nfss
|
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ nfs_group_name|default('nfss') }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
|
|
- name: stop ceph nfss with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: nfs-ganesha
|
|
|
|
|
state: stopped
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2016-03-29 07:53:01 +08:00
|
|
|
|
|
2016-05-06 02:20:03 +08:00
|
|
|
|
- name: stop ceph nfss
|
|
|
|
|
shell: "service nfs-ganesha status ; if [ $? == 0 ] ; then service nfs-ganesha stop ; else echo ; fi"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'sysvinit'
|
2016-05-06 02:20:03 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph nfss on ubuntu
|
|
|
|
|
command: initctl stop nfs-ganesha
|
2015-07-29 00:21:15 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2015-07-08 16:34:16 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: purge ceph osd cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
|
|
|
|
osd_group_name: osds
|
2017-10-26 20:18:38 +08:00
|
|
|
|
reboot_osd_node: False
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ osd_group_name|default('osds') }}"
|
2016-10-06 12:32:38 +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
|
2017-11-29 18:10:56 +08:00
|
|
|
|
local_action: wait_for port=22 host={{ hostvars[inventory_hostname]['ansible_default_ipv4']['address'] }} state=started delay=10 timeout=500
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: remove data
|
|
|
|
|
file:
|
|
|
|
|
path: /var/lib/ceph
|
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
2017-09-27 04:14:29 +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
|
|
|
|
- name: get osd numbers
|
2017-03-30 17:51:38 +08:00
|
|
|
|
shell: "if [ -d /var/lib/ceph/osd ] ; then ls /var/lib/ceph/osd | sed 's/.*-//' ; fi"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
register: osd_ids
|
|
|
|
|
changed_when: false
|
|
|
|
|
|
|
|
|
|
- name: stop ceph-osd with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: ceph-osd@{{item}}
|
|
|
|
|
state: stopped
|
|
|
|
|
enabled: no
|
|
|
|
|
with_items: "{{ osd_ids.stdout_lines }}"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2016-05-06 02:20:03 +08:00
|
|
|
|
|
2017-01-27 18:33:37 +08:00
|
|
|
|
# before infernalis release, using sysvinit scripts
|
|
|
|
|
# we use this test so we do not have to know which RPM contains the boot script
|
|
|
|
|
# or where it is placed.
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: stop ceph osds
|
|
|
|
|
shell: "service ceph status osd ; if [ $? == 0 ] ; then service ceph stop osd ; else echo ; fi"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'sysvinit'
|
2016-03-29 07:53:01 +08:00
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: stop ceph osds on ubuntu
|
2017-03-30 17:51:38 +08:00
|
|
|
|
command: initctl stop ceph-osd cluster={{ cluster }} id={{ item }}
|
2016-04-04 06:35:09 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
with_items: "{{ osd_ids.stdout_lines }}"
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
2017-09-01 00:22:34 +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
|
|
|
|
|
|
2016-04-07 03:58:17 +08:00
|
|
|
|
- name: see if ceph-disk-created data partitions are present
|
2016-08-26 23:39:43 +08:00
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*.data"
|
2016-04-07 03:58:17 +08:00
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_data_partlabels
|
|
|
|
|
|
2017-09-29 14:04:17 +08:00
|
|
|
|
- name: see if ceph-disk-created block partitions are present
|
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*block$"
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_block_partlabels
|
|
|
|
|
|
2016-04-07 03:58:17 +08:00
|
|
|
|
- name: see if ceph-disk-created journal partitions are present
|
2016-08-26 23:39:43 +08:00
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*.journal"
|
2016-04-07 03:58:17 +08:00
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_journal_partlabels
|
|
|
|
|
|
2017-08-22 00:08:18 +08:00
|
|
|
|
- name: see if ceph-disk-created block db partitions are present
|
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*.block.db"
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_db_partlabels
|
|
|
|
|
|
|
|
|
|
- name: see if ceph-disk-created block wal partitions are present
|
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*.block.wal"
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_wal_partlabels
|
|
|
|
|
|
2017-09-01 00:22:34 +08:00
|
|
|
|
- name: see if ceph-disk-created lockbox partitions are present
|
|
|
|
|
shell: |
|
|
|
|
|
ls /dev/disk/by-partlabel | grep -q "ceph.*.lockbox"
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_lockbox_partlabels
|
|
|
|
|
|
2017-01-19 22:28:44 +08:00
|
|
|
|
# Initial attempt, doing everything in Ansible...
|
|
|
|
|
# - name: see if encrypted partitions are present
|
|
|
|
|
# shell: blkid -t TYPE=crypto_LUKS -o value -s PARTUUID
|
|
|
|
|
# register: encrypted_partuuid
|
|
|
|
|
#
|
|
|
|
|
# - name: find if these encrypted partitions are ceph data partitions
|
|
|
|
|
# shell: blkid -t PARTLABEL="ceph data" -o value -s PARTUUID $(blkid -U {{ item }})
|
|
|
|
|
# failed_when: false
|
|
|
|
|
# with_items: "{{ encrypted_partuuid.stdout_lines }}"
|
|
|
|
|
# when: "{{ encrypted_partuuid | length > 0 }}"
|
|
|
|
|
# register: encrypted_partuuid_ceph_data
|
|
|
|
|
#
|
|
|
|
|
# - name: find if these encrypted partitions are ceph journal partitions
|
|
|
|
|
# shell: blkid -t PARTLABEL="ceph journal" -o value -s PARTUUID $(blkid -U {{ item }})
|
|
|
|
|
# failed_when: false
|
|
|
|
|
# with_items: "{{ encrypted_partuuid.stdout_lines }}"
|
|
|
|
|
# when: "{{ encrypted_partuuid | length > 0 }}"
|
|
|
|
|
# register: encrypted_partuuid_ceph_journal
|
|
|
|
|
#
|
|
|
|
|
# - name: merge the list of ceph encrypted partitions
|
|
|
|
|
# set_fact:
|
|
|
|
|
# encrypted_partuuid_ceph: "{{ encrypted_partuuid_ceph_data + encrypted_partuuid_ceph_journal }}"
|
|
|
|
|
|
|
|
|
|
# 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
|
|
|
|
|
|
2017-09-01 00:22:34 +08:00
|
|
|
|
- name: get osd data and lockbox mount points
|
|
|
|
|
shell: "(grep /var/lib/ceph /proc/mounts || echo -n) | awk '{ print $2 }'"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
register: mounted_osd
|
|
|
|
|
changed_when: false
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
|
|
|
|
- name: drop all cache
|
|
|
|
|
shell: "sync && sleep 1 && echo 3 > /proc/sys/vm/drop_caches"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
|
|
|
|
- name: umount osd data partition
|
2016-03-23 01:29:00 +08:00
|
|
|
|
shell: umount {{ item }}
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ mounted_osd.stdout_lines }}"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2016-03-23 01:29:00 +08:00
|
|
|
|
- name: remove osd mountpoint tree
|
2016-08-10 10:53:07 +08:00
|
|
|
|
file:
|
|
|
|
|
path: /var/lib/ceph/osd/
|
|
|
|
|
state: absent
|
2016-03-23 01:29:00 +08:00
|
|
|
|
register: remove_osd_mountpoints
|
2016-08-10 10:53:07 +08:00
|
|
|
|
ignore_errors: true
|
2016-03-24 20:49:26 +08:00
|
|
|
|
|
2016-03-23 01:29:00 +08:00
|
|
|
|
- name: is reboot needed
|
|
|
|
|
local_action: shell echo requesting reboot
|
2016-09-03 07:31:59 +08:00
|
|
|
|
become: false
|
2016-03-23 01:29:00 +08:00
|
|
|
|
notify:
|
|
|
|
|
- restart machine
|
|
|
|
|
- wait for server to boot
|
|
|
|
|
- remove data
|
2017-10-26 20:18:38 +08:00
|
|
|
|
when:
|
|
|
|
|
- reboot_osd_node
|
|
|
|
|
- remove_osd_mountpoints.failed is defined
|
2016-03-23 01:29:00 +08:00
|
|
|
|
|
2016-04-07 03:58:17 +08:00
|
|
|
|
- name: see if ceph-disk is installed
|
|
|
|
|
shell: "which ceph-disk"
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_disk_present
|
|
|
|
|
|
2017-01-19 22:28:44 +08:00
|
|
|
|
- name: delete dm-crypt devices if any
|
2017-09-01 00:22:34 +08:00
|
|
|
|
command: dmsetup remove --retry --force {{ item }}
|
2017-01-27 01:28:30 +08:00
|
|
|
|
with_items: "{{ encrypted_ceph_partuuid.stdout_lines }}"
|
2017-01-19 22:28:44 +08:00
|
|
|
|
when: "{{ encrypted_ceph_partuuid.stdout_lines | length > 0 }}"
|
|
|
|
|
|
2017-08-29 05:27:01 +08:00
|
|
|
|
- name: get ceph data partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk -F: '/ceph data/ { print $1 }'
|
|
|
|
|
when: ceph_data_partlabels.rc == 0
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_data_partition_to_erase_path
|
|
|
|
|
|
2017-09-01 00:22:34 +08:00
|
|
|
|
- name: get ceph lockbox partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk '/ceph lockbox/ { sub (":", "", $1); print $1 }'
|
|
|
|
|
when: ceph_lockbox_partlabels.rc == 0
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_lockbox_partition_to_erase_path
|
|
|
|
|
|
2016-02-10 20:13:39 +08:00
|
|
|
|
- name: zap osd disks
|
2017-07-18 14:56:12 +08:00
|
|
|
|
shell: |
|
|
|
|
|
if (echo "{{ item }}" | grep -Esq '[0-9]{1,2}$'); then
|
|
|
|
|
raw_device=$(echo "{{ item }}" | grep -Eo '/dev/([hsv]d[a-z]{1,2}|cciss/c[0-9]d[0-9]|nvme[0-9]n[0-9]){1,2}')
|
|
|
|
|
partition_nb=$(echo "{{ item }}" | grep -Eo '[0-9]{1,2}$')
|
|
|
|
|
sgdisk --delete $partition_nb $raw_device
|
2017-09-01 00:22:34 +08:00
|
|
|
|
udevadm settle --timeout=600
|
2017-07-18 14:56:12 +08:00
|
|
|
|
else
|
|
|
|
|
ceph-disk zap "{{ item }}"
|
2017-09-01 00:22:34 +08:00
|
|
|
|
udevadm settle --timeout=600
|
2017-07-18 14:56:12 +08:00
|
|
|
|
fi
|
2017-09-01 00:22:34 +08:00
|
|
|
|
with_items:
|
|
|
|
|
- "{{ ceph_data_partition_to_erase_path.stdout_lines | default([]) }}"
|
|
|
|
|
- "{{ ceph_lockbox_partition_to_erase_path.stdout_lines | default([]) }}"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
when:
|
2017-01-18 17:53:21 +08:00
|
|
|
|
- ceph_disk_present.rc == 0
|
2017-10-10 15:57:39 +08:00
|
|
|
|
- (ceph_data_partlabels.rc == 0 or ceph_lockbox_partlabels.rc == 0)
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2017-08-23 22:12:40 +08:00
|
|
|
|
# this should go away once 'ceph-volume lvm zap' is available
|
|
|
|
|
- name: remove osd logical volumes
|
|
|
|
|
command: "lvremove -f {{ item.data_vg }}/{{ item.data }}"
|
|
|
|
|
with_items: "{{ lvm_volumes }}"
|
|
|
|
|
when:
|
|
|
|
|
- osd_scenario == "lvm"
|
|
|
|
|
|
|
|
|
|
# this should go away once 'ceph-volume lvm zap' is available
|
|
|
|
|
- name: remove osd lvm journals
|
|
|
|
|
command: "lvremove -f {{ item.journal_vg }}/{{ item.journal }}"
|
|
|
|
|
with_items: "{{ lvm_volumes }}"
|
|
|
|
|
# journals might be logical volumes, but they could also be
|
|
|
|
|
# devices so fail silently if this doesn't work
|
|
|
|
|
failed_when: false
|
|
|
|
|
when:
|
|
|
|
|
- osd_scenario == "lvm"
|
|
|
|
|
- item.journal_vg is defined
|
|
|
|
|
|
2017-09-29 14:04:17 +08:00
|
|
|
|
- name: get ceph block partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk '/ceph block"/ { sub (":", "", $1); print $1 }'
|
|
|
|
|
when: ceph_block_partlabels.rc == 0
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_block_partition_to_erase_path
|
|
|
|
|
|
2016-12-23 03:47:22 +08:00
|
|
|
|
- name: get ceph journal partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk '/ceph journal/ { sub (":", "", $1); print $1 }'
|
2017-01-18 17:53:21 +08:00
|
|
|
|
when: ceph_journal_partlabels.rc == 0
|
2016-12-23 03:47:22 +08:00
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_journal_partition_to_erase_path
|
|
|
|
|
|
2017-08-22 00:08:18 +08:00
|
|
|
|
- name: get ceph db partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk '/ceph block.db/ { sub (":", "", $1); print $1 }'
|
|
|
|
|
when: ceph_db_partlabels.rc == 0
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_db_partition_to_erase_path
|
|
|
|
|
|
|
|
|
|
- name: get ceph wal partitions
|
|
|
|
|
shell: |
|
|
|
|
|
blkid | awk '/ceph block.wal/ { sub (":", "", $1); print $1 }'
|
|
|
|
|
when: ceph_wal_partlabels.rc == 0
|
|
|
|
|
failed_when: false
|
|
|
|
|
register: ceph_wal_partition_to_erase_path
|
|
|
|
|
|
2017-09-01 00:22:34 +08:00
|
|
|
|
- name: zap ceph journal/block db/block wal partitions
|
2016-08-26 23:39:43 +08:00
|
|
|
|
shell: |
|
|
|
|
|
# if the disk passed is a raw device AND the boot system disk
|
|
|
|
|
if echo "{{ item }}" | egrep -sq '/dev/([hsv]d[a-z]{1,2}|cciss/c[0-9]d[0-9]p|nvme[0-9]n[0-9]p){1,2}$' && parted -s $(echo "{{ item }}" | egrep -o '/dev/([hsv]d[a-z]{1,2}|cciss/c[0-9]d[0-9]p|nvme[0-9]n[0-9]p){1,2}') print | grep -sq boot; then
|
|
|
|
|
echo "Looks like {{ item }} has a boot partition,"
|
|
|
|
|
echo "if you want to delete specific partitions point to the partition instead of the raw device"
|
|
|
|
|
echo "Do not use your system disk!"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
2017-04-11 20:59:49 +08:00
|
|
|
|
raw_device=$(echo "{{ item }}" | egrep -o '/dev/([hsv]d[a-z]{1,2}|cciss/c[0-9]d[0-9]|nvme[0-9]n[0-9]){1,2}')
|
2016-08-26 23:39:43 +08:00
|
|
|
|
partition_nb=$(echo "{{ item }}" | egrep -o '[0-9]{1,2}$')
|
|
|
|
|
sgdisk --delete $partition_nb $raw_device
|
2017-08-22 00:08:18 +08:00
|
|
|
|
with_items:
|
2017-09-29 14:04:17 +08:00
|
|
|
|
- "{{ ceph_block_partition_to_erase_path.stdout_lines | default([]) }}"
|
2017-08-22 00:08:18 +08:00
|
|
|
|
- "{{ ceph_journal_partition_to_erase_path.stdout_lines | default([]) }}"
|
|
|
|
|
- "{{ ceph_db_partition_to_erase_path.stdout_lines | default([]) }}"
|
|
|
|
|
- "{{ ceph_wal_partition_to_erase_path.stdout_lines | default([]) }}"
|
2016-02-29 20:19:56 +08:00
|
|
|
|
when:
|
2017-09-29 14:04:17 +08:00
|
|
|
|
- (ceph_block_partlabels.rc == 0 or ceph_journal_partlabels.rc == 0 or ceph_db_partlabels.rc == 0 or ceph_wal_partlabels.rc == 0)
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: purge ceph mon cluster
|
|
|
|
|
|
|
|
|
|
vars:
|
2016-11-01 19:39:21 +08:00
|
|
|
|
mon_group_name: mons
|
|
|
|
|
restapi_group_name: restapis
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +08:00
|
|
|
|
- "{{ mon_group_name|default('mons') }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
2017-08-05 02:18:11 +08:00
|
|
|
|
gather_facts: false # already gathered previously
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
|
|
|
|
- name: stop ceph mons with systemd
|
|
|
|
|
service:
|
|
|
|
|
name: ceph-mon@{{ ansible_hostname }}
|
|
|
|
|
state: stopped
|
|
|
|
|
enabled: no
|
2017-10-07 04:52:53 +08:00
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: stop ceph mons
|
|
|
|
|
shell: "service ceph status mon ; if [ $? == 0 ] ; then service ceph stop mon ; else echo ; fi"
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'sysvinit'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: stop ceph mons on ubuntu
|
|
|
|
|
command: initctl stop ceph-mon cluster={{ cluster }} id={{ ansible_hostname }}
|
|
|
|
|
failed_when: false
|
2017-02-08 01:57:38 +08:00
|
|
|
|
when: ansible_service_mgr == 'upstart'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: remove monitor store and bootstrap keys
|
|
|
|
|
file:
|
2017-09-14 07:07:04 +08:00
|
|
|
|
path: "{{ item }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
state: absent
|
2017-09-14 07:07:04 +08:00
|
|
|
|
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
|
|
|
|
|
|
|
|
|
- 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
|
|
|
|
|
- ceph-common
|
|
|
|
|
- ceph-fs-common
|
|
|
|
|
- ceph-fuse
|
|
|
|
|
- ceph-mds
|
2017-09-24 00:02:49 +08:00
|
|
|
|
- ceph-mgr
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- ceph-release
|
|
|
|
|
- ceph-radosgw
|
2017-02-14 23:24:02 +08:00
|
|
|
|
- calamari-server
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
ceph_remaining_packages:
|
|
|
|
|
- libcephfs1
|
2016-12-09 23:42:04 +08:00
|
|
|
|
- libcephfs2
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- librados2
|
|
|
|
|
- libradosstriper1
|
|
|
|
|
- librbd1
|
|
|
|
|
- python-cephfs
|
|
|
|
|
- python-rados
|
|
|
|
|
- python-rbd
|
|
|
|
|
|
|
|
|
|
hosts:
|
2017-03-08 00:16:09 +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') }}"
|
|
|
|
|
- "{{ client_group_name|default('clients') }}"
|
2017-09-24 00:02:49 +08:00
|
|
|
|
- "{{ mgr_group_name|default('mgrs') }}"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
gather_facts: false # Already gathered previously
|
|
|
|
|
|
|
|
|
|
become: true
|
|
|
|
|
|
|
|
|
|
handlers:
|
2017-09-01 00:22:34 +08:00
|
|
|
|
- name: get osd data and lockbox mount points
|
|
|
|
|
shell: "(grep /var/lib/ceph /proc/mounts || echo -n) | awk '{ print $2 }'"
|
|
|
|
|
register: mounted_osd
|
|
|
|
|
changed_when: false
|
|
|
|
|
listen: "remove data"
|
|
|
|
|
|
|
|
|
|
- name: umount osd data partition
|
|
|
|
|
shell: umount {{ item }}
|
|
|
|
|
with_items: "{{ mounted_osd.stdout_lines }}"
|
|
|
|
|
listen: "remove data"
|
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: remove data
|
|
|
|
|
file:
|
|
|
|
|
path: /var/lib/ceph
|
|
|
|
|
state: absent
|
2017-09-01 00:22:34 +08:00
|
|
|
|
listen: "remove data"
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
tasks:
|
2017-01-27 22:40:41 +08:00
|
|
|
|
|
2016-02-15 23:01:00 +08:00
|
|
|
|
- name: purge ceph packages with yum
|
|
|
|
|
yum:
|
2016-02-10 20:13:39 +08:00
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_packages }}"
|
|
|
|
|
when: ansible_pkg_mgr == 'yum'
|
2016-02-15 23:51:16 +08:00
|
|
|
|
|
|
|
|
|
- name: purge ceph packages with dnf
|
|
|
|
|
dnf:
|
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_packages }}"
|
|
|
|
|
when: ansible_pkg_mgr == 'dnf'
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
2016-02-15 23:01:00 +08:00
|
|
|
|
- name: purge ceph packages with apt
|
|
|
|
|
apt:
|
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_packages }}"
|
|
|
|
|
when: ansible_pkg_mgr == 'apt'
|
2016-02-15 23:01:00 +08:00
|
|
|
|
|
|
|
|
|
- name: purge remaining ceph packages with yum
|
|
|
|
|
yum:
|
2016-02-10 20:13:39 +08:00
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_remaining_packages }}"
|
2016-02-10 20:13:39 +08:00
|
|
|
|
when:
|
2017-01-18 17:53:21 +08:00
|
|
|
|
- ansible_pkg_mgr == 'yum'
|
|
|
|
|
- purge_all_packages == true
|
2016-02-15 23:51:16 +08:00
|
|
|
|
|
|
|
|
|
- name: purge remaining ceph packages with dnf
|
|
|
|
|
dnf:
|
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_remaining_packages }}"
|
2016-02-15 23:51:16 +08:00
|
|
|
|
when:
|
2017-01-18 17:53:21 +08:00
|
|
|
|
- ansible_pkg_mgr == 'dnf'
|
|
|
|
|
- purge_all_packages == true
|
2016-02-15 23:01:00 +08:00
|
|
|
|
|
|
|
|
|
- name: purge remaining ceph packages with apt
|
|
|
|
|
apt:
|
|
|
|
|
name: "{{ item }}"
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
with_items: "{{ ceph_remaining_packages }}"
|
2016-02-15 23:01:00 +08:00
|
|
|
|
when:
|
2017-01-18 17:53:21 +08:00
|
|
|
|
- ansible_pkg_mgr == 'apt'
|
|
|
|
|
- purge_all_packages == true
|
2016-02-10 20:13:39 +08:00
|
|
|
|
|
|
|
|
|
- name: remove config
|
|
|
|
|
file:
|
|
|
|
|
path: /etc/ceph
|
|
|
|
|
state: absent
|
|
|
|
|
|
|
|
|
|
- name: remove logs
|
|
|
|
|
file:
|
|
|
|
|
path: /var/log/ceph
|
|
|
|
|
state: absent
|
|
|
|
|
|
2016-03-23 01:29:00 +08:00
|
|
|
|
- name: request data removal
|
|
|
|
|
local_action: shell echo requesting data removal
|
2016-08-10 10:53:07 +08:00
|
|
|
|
become: false
|
2016-03-23 01:29:00 +08:00
|
|
|
|
notify:
|
|
|
|
|
- remove data
|
|
|
|
|
|
2016-03-29 07:53:01 +08:00
|
|
|
|
- name: purge dnf cache
|
|
|
|
|
command: dnf clean all
|
2017-01-18 17:53:21 +08:00
|
|
|
|
when: ansible_pkg_mgr == 'dnf'
|
2016-03-29 07:53:01 +08:00
|
|
|
|
|
2017-01-27 18:33:37 +08:00
|
|
|
|
- name: purge rpm cache in /tmp
|
2016-04-28 01:36:32 +08:00
|
|
|
|
file:
|
|
|
|
|
path: /tmp/rh-storage-repo
|
|
|
|
|
state: absent
|
2016-04-27 01:01:01 +08:00
|
|
|
|
|
2016-03-29 07:53:01 +08:00
|
|
|
|
- name: clean apt
|
|
|
|
|
shell: apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
|
2017-01-18 17:53:21 +08:00
|
|
|
|
when: ansible_pkg_mgr == 'apt'
|
2016-06-02 18:08:19 +08:00
|
|
|
|
|
|
|
|
|
- name: purge rh_storage.repo file in /etc/yum.repos.d
|
|
|
|
|
file:
|
|
|
|
|
path: /etc/yum.repos.d/rh_storage.repo
|
|
|
|
|
state: absent
|
2017-01-18 17:53:21 +08:00
|
|
|
|
when: ansible_os_family == 'RedHat'
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
2017-04-25 20:35:13 +08:00
|
|
|
|
- name: check for anything running ceph
|
|
|
|
|
command: "ps -u ceph -U ceph"
|
|
|
|
|
register: check_for_running_ceph
|
|
|
|
|
failed_when: check_for_running_ceph.rc == 0
|
|
|
|
|
|
2017-11-16 18:49:18 +08:00
|
|
|
|
- name: find ceph systemd unit files to remove
|
|
|
|
|
find:
|
|
|
|
|
paths: "/etc/systemd/system"
|
|
|
|
|
pattern: "ceph*"
|
|
|
|
|
register: systemd_files
|
|
|
|
|
|
2017-07-25 18:04:57 +08:00
|
|
|
|
- name: remove ceph systemd unit files
|
2017-10-07 04:54:34 +08:00
|
|
|
|
file:
|
2017-11-16 18:49:18 +08:00
|
|
|
|
path: "{{ item.path }}"
|
2017-10-07 04:54:34 +08:00
|
|
|
|
state: absent
|
2017-11-16 18:49:18 +08:00
|
|
|
|
with_items:
|
|
|
|
|
- "{{ systemd_files.files }}"
|
2017-07-25 18:04:57 +08:00
|
|
|
|
when: ansible_service_mgr == 'systemd'
|
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
|
|
|
|
|
- name: purge fetch directory
|
|
|
|
|
|
|
|
|
|
hosts:
|
|
|
|
|
- localhost
|
|
|
|
|
|
|
|
|
|
gather_facts: false
|
|
|
|
|
|
|
|
|
|
tasks:
|
|
|
|
|
|
2017-02-08 04:42:42 +08:00
|
|
|
|
- name: set fetch_directory value if not set
|
|
|
|
|
set_fact:
|
|
|
|
|
fetch_directory: "fetch/"
|
|
|
|
|
when: fetch_directory is not defined
|
|
|
|
|
|
2016-10-06 12:32:38 +08:00
|
|
|
|
- name: purge fetch directory for localhost
|
|
|
|
|
file:
|
|
|
|
|
path: "{{ fetch_directory }}"
|
|
|
|
|
state: absent
|