|  | package com.mirantis.mk | 
|  |  | 
|  | /** | 
|  | * | 
|  | * Ceph functions | 
|  | * | 
|  | */ | 
|  |  | 
|  | /** | 
|  | * Ceph health check | 
|  | * | 
|  | */ | 
|  | def waitForHealthy(master, target, flags=[], count=0, attempts=300) { | 
|  | def common = new com.mirantis.mk.Common() | 
|  | def salt = new com.mirantis.mk.Salt() | 
|  | // wait for healthy cluster | 
|  | while (count < attempts) { | 
|  | def health = salt.cmdRun(master, target, 'ceph health')['return'][0].values()[0] | 
|  | if (health.contains('HEALTH_OK')) { | 
|  | common.infoMsg('Cluster is healthy') | 
|  | break | 
|  | } else { | 
|  | for (flag in flags) { | 
|  | if (health.contains(flag + ' flag(s) set') && !(health.contains('down'))) { | 
|  | common.infoMsg('Cluster is healthy') | 
|  | return | 
|  | } | 
|  | } | 
|  | } | 
|  | common.infoMsg("Ceph health status: ${health}") | 
|  | count++ | 
|  | sleep(10) | 
|  | } | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Ceph remove partition | 
|  | * | 
|  | */ | 
|  | def removePartition(master, target, partition_uuid, type='', id=-1) { | 
|  | def salt = new com.mirantis.mk.Salt() | 
|  | def common = new com.mirantis.mk.Common() | 
|  | def partition = "" | 
|  | if (type == 'lockbox') { | 
|  | try { | 
|  | // umount - partition = /dev/sdi2 | 
|  | partition = salt.cmdRun(master, target, "lsblk -rp | grep -v mapper | grep ${partition_uuid} ")['return'][0].values()[0].split()[0] | 
|  | salt.cmdRun(master, target, "umount ${partition}") | 
|  | } catch (Exception e) { | 
|  | common.warningMsg(e) | 
|  | } | 
|  | } else if (type == 'data') { | 
|  | try { | 
|  | // umount - partition = /dev/sdi2 | 
|  | partition = salt.cmdRun(master, target, "df | grep /var/lib/ceph/osd/ceph-${id}")['return'][0].values()[0].split()[0] | 
|  | salt.cmdRun(master, target, "umount ${partition}") | 
|  | } catch (Exception e) { | 
|  | common.warningMsg(e) | 
|  | } | 
|  | try { | 
|  | // partition = /dev/sdi2 | 
|  | partition = salt.cmdRun(master, target, "blkid | grep ${partition_uuid} ")['return'][0].values()[0].split(":")[0] | 
|  | } catch (Exception e) { | 
|  | common.warningMsg(e) | 
|  | } | 
|  | } else { | 
|  | try { | 
|  | // partition = /dev/sdi2 | 
|  | partition = salt.cmdRun(master, target, "blkid | grep ${partition_uuid} ")['return'][0].values()[0].split(":")[0] | 
|  | } catch (Exception e) { | 
|  | common.warningMsg(e) | 
|  | } | 
|  | } | 
|  | if (partition?.trim()) { | 
|  | if (partition.contains("nvme")) { | 
|  | // partition = /dev/nvme1n1p2 | 
|  | // dev = /dev/nvme1n1 | 
|  | def dev = partition.replaceAll('p\\d+$', "") | 
|  | // part_id = 2 | 
|  | def part_id = partition.substring(partition.lastIndexOf("p") + 1).replaceAll("[^0-9]+", "") | 
|  |  | 
|  | } else { | 
|  | // partition = /dev/sdi2 | 
|  | // dev = /dev/sdi | 
|  | def dev = partition.replaceAll('\\d+$', "") | 
|  | // part_id = 2 | 
|  | def part_id = partition.substring(partition.lastIndexOf("/") + 1).replaceAll("[^0-9]+", "") | 
|  | } | 
|  | salt.cmdRun(master, target, "Ignore | parted ${dev} rm ${part_id}") | 
|  | } | 
|  | return | 
|  | } |