[pve-devel] [PATCH storage v2] Diskmanage: add flag for encrypted osds
Dominik Csapak
d.csapak at proxmox.com
Fri Jul 12 12:15:15 CEST 2019
we can only do this here, since the ceph cluster is not aware of
osd encryption, only the local node is (via ceph-volume and lv tags)
this way, we are able to show an 'encrypted' flag in the disk gui at least
Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
changes from v1:
* use the same logic like blustore
* add one test and fix the rest
PVE/Diskmanage.pm | 6 ++++++
test/disk_tests/usages/disklist_expected.json | 4 ++++
test/disk_tests/usages/lvs | 2 +-
3 files changed, 11 insertions(+), 1 deletion(-)
diff --git a/PVE/Diskmanage.pm b/PVE/Diskmanage.pm
index 196eee5..2a0a015 100644
--- a/PVE/Diskmanage.pm
+++ b/PVE/Diskmanage.pm
@@ -292,6 +292,9 @@ sub get_ceph_volume_infos {
if (($type eq 'block' || $type eq 'data') && $fields->[2] =~ m/ceph.osd_id=([^,]+)/) {
$result->{$dev}->{osdid} = $1;
$result->{$dev}->{bluestore} = ($type eq 'block');
+ if ($fields->[2] =~ m/ceph\.encrypted=1/) {
+ $result->{$dev}->{encrypted} = 1;
+ }
} else {
# undef++ becomes '1' (see `perldoc perlop`: Auto-increment)
$result->{$dev}->{$type}++;
@@ -582,6 +585,7 @@ sub get_disks {
my $osdid = -1;
my $bluestore = 0;
+ my $osdencrypted = 0;
my $journal_count = 0;
my $db_count = 0;
@@ -638,6 +642,7 @@ sub get_disks {
if (defined($ceph_volume->{osdid})) {
$osdid = $ceph_volume->{osdid};
$bluestore = 1 if $ceph_volume->{bluestore};
+ $osdencrypted = 1 if $ceph_volume->{encrypted};
}
}
@@ -656,6 +661,7 @@ sub get_disks {
$disklist->{$dev}->{osdid} = $osdid;
$disklist->{$dev}->{journals} = $journal_count if $journal_count;
$disklist->{$dev}->{bluestore} = $bluestore if $osdid != -1;
+ $disklist->{$dev}->{osdencrypted} = $osdencrypted if $osdid != -1;
$disklist->{$dev}->{db} = $db_count if $db_count;
$disklist->{$dev}->{wal} = $wal_count if $wal_count;
});
diff --git a/test/disk_tests/usages/disklist_expected.json b/test/disk_tests/usages/disklist_expected.json
index b179cd6..b2e37c0 100644
--- a/test/disk_tests/usages/disklist_expected.json
+++ b/test/disk_tests/usages/disklist_expected.json
@@ -4,6 +4,7 @@
"rpm" : 0,
"size" : 1536000,
"type" : "hdd",
+ "osdencrypted": 0,
"osdid" : "444",
"bluestore" : "0",
"health" : "UNKNOWN",
@@ -104,6 +105,7 @@
"rpm" : 0,
"type" : "hdd",
"bluestore": 1,
+ "osdencrypted": 0,
"osdid" : 1
},
"sdh" : {
@@ -152,6 +154,7 @@
"rpm" : 0,
"bluestore": 0,
"type" : "hdd",
+ "osdencrypted": 1,
"osdid" : 0
},
"sdk" : {
@@ -168,6 +171,7 @@
"rpm" : 0,
"bluestore": 0,
"type" : "hdd",
+ "osdencrypted": 0,
"osdid" : 230
},
"sdl" : {
diff --git a/test/disk_tests/usages/lvs b/test/disk_tests/usages/lvs
index 8d640e1..3720a80 100644
--- a/test/disk_tests/usages/lvs
+++ b/test/disk_tests/usages/lvs
@@ -1,6 +1,6 @@
/dev/sdg(0);osd-block-01234;ceph.osd_id=1
/dev/sdh(0);osd-journal-01234;ceph.osd_id=1
/dev/sdi(0);osd-db-01234;ceph.osd_id=1,dasdf
-/dev/sdj(0);osd-data-01234;ceph.osd_id=0,asfd
+/dev/sdj(0);osd-data-01234;ceph.osd_id=0,asfd,ceph.encrypted=1
/dev/sdk(0);osd-data-231231;ceph.osd_id=230,ceph.fsid=test
/dev/sdl(0);osd-data-234132;ceph.osd_id=,bar
--
2.20.1
More information about the pve-devel
mailing list