add optional step for wipe orpaned ceph's partitions
Related-Prod: PROD-35177
Change-Id: Ie228d0491a4da3d2f14d5a2f8c7f21f09ed1b15f
diff --git a/ceph-remove-osd.groovy b/ceph-remove-osd.groovy
index 015dcd2..7b00aa5 100644
--- a/ceph-remove-osd.groovy
+++ b/ceph-remove-osd.groovy
@@ -11,6 +11,8 @@
* ADMIN_HOST Host (minion id) with admin keyring
* CLUSTER_FLAGS Comma separated list of tags to apply to cluster
* WAIT_FOR_HEALTHY Wait for cluster rebalance before stoping daemons
+ * CLEANDISK Wipe data disk of removed osd
+ * CLEAN_ORPHANS Wipe partition left over after unknown osd
*
*/
@@ -22,7 +24,8 @@
def pepperEnv = "pepperEnv"
def flags = CLUSTER_FLAGS.tokenize(',')
def osds = OSD.tokenize(',')
-def cleanDisk = CLEANDISK
+def cleanDisk = CLEANDISK.toBoolean()
+def cleanOrphans = CLEAN_ORPHANS.toBoolean()
timeout(time: 12, unit: 'HOURS') {
node("python") {
@@ -207,6 +210,22 @@
}
}
}
+ if (cleanOrphans) {
+ stage('Remove orphan partitions') {
+ def orphans = []
+ def disks = salt.cmdRun(pepperEnv, ADMIN_HOST, "ceph-disk list --format json")['return'][0].values()[0]
+ for (disk in disks) {
+ for (partition in disk.get('partitions')) {
+ if (partition.get('type') == 'block.db' && !partition.containsKey('block.db_for')) {
+ orphans.add(partition['uuid'])
+ }
+ }
+ }
+ for (orphan in orphans) {
+ ceph.removePartition(pepperEnv, HOST, orphan)
+ }
+ }
+ }
}
finally {
// remove cluster flags