[pve-devel] [PATCH storage v4 03/19] rbd: implement handling of unset monhost
Fabian Grünbichler
f.gruenbichler at proxmox.com
Tue Sep 5 14:59:32 CEST 2017
add /etc/pve/ceph.conf to commands / option strings instead
of the monitor list provided via the 'monhost' option.
Signed-off-by: Fabian Grünbichler <f.gruenbichler at proxmox.com>
---
changes since v3:
- adapt to pveceph flag no longer existing
PVE/Storage/RBDPlugin.pm | 40 +++++++++++++++++++++++++++++++---------
1 file changed, 31 insertions(+), 9 deletions(-)
diff --git a/PVE/Storage/RBDPlugin.pm b/PVE/Storage/RBDPlugin.pm
index 12a3458..942c2ad 100644
--- a/PVE/Storage/RBDPlugin.pm
+++ b/PVE/Storage/RBDPlugin.pm
@@ -10,6 +10,8 @@ use PVE::JSONSchema qw(get_standard_option);
use base qw(PVE::Storage::Plugin);
+my $pveceph_config = '/etc/pve/ceph.conf';
+
my $rbd_unittobytes = {
"k" => 1024,
"M" => 1024*1024,
@@ -40,13 +42,18 @@ my $hostlist = sub {
my $build_cmd = sub {
my ($binary, $scfg, $storeid, $op, @options) = @_;
- my $monhost = &$hostlist($scfg->{monhost}, ',');
-
my $keyring = "/etc/pve/priv/ceph/${storeid}.keyring";
my $pool = $scfg->{pool} ? $scfg->{pool} : 'rbd';
my $username = $scfg->{username} ? $scfg->{username} : 'admin';
- my $cmd = [$binary, '-p', $pool, '-m', $monhost];
+ my $cmd = [$binary, '-p', $pool];
+ my $pveceph_managed = !defined($scfg->{monhost});
+
+ if ($pveceph_managed) {
+ push @$cmd, '-c', $pveceph_config;
+ } else {
+ push @$cmd, '-m', $hostlist->($scfg->{monhost}, ',');
+ }
if (-e $keyring) {
push @$cmd, '-n', "client.$username";
@@ -59,7 +66,11 @@ my $build_cmd = sub {
my $cephconfig = "/etc/pve/priv/ceph/${storeid}.conf";
if (-e $cephconfig) {
- push @$cmd, '-c', $cephconfig;
+ if ($pveceph_managed) {
+ warn "ignoring custom ceph config for storage '$storeid', 'monhost' is not set (assuming pveceph managed cluster)!\n";
+ } else {
+ push @$cmd, '-c', $cephconfig;
+ }
}
push @$cmd, $op;
@@ -293,12 +304,19 @@ sub path {
my $pool = $scfg->{pool} ? $scfg->{pool} : 'rbd';
return ("/dev/rbd/$pool/$name", $vmid, $vtype) if $scfg->{krbd};
- my $monhost = &$hostlist($scfg->{monhost}, ';');
- $monhost =~ s/:/\\:/g;
-
my $username = $scfg->{username} ? $scfg->{username} : 'admin';
- my $path = "rbd:$pool/$name:mon_host=$monhost";
+ my $path = "rbd:$pool/$name";
+ my $pveceph_managed = !defined($scfg->{monhost});
+
+ if ($pveceph_managed) {
+ $path .= ":conf=$pveceph_config";
+ } else {
+ my $monhost = $hostlist->($scfg->{monhost}, ';');
+ $monhost =~ s/:/\\:/g;
+ $path .= ":mon_host=$monhost";
+ }
+
my $keyring = "/etc/pve/priv/ceph/${storeid}.keyring";
if (-e $keyring) {
@@ -310,7 +328,11 @@ sub path {
my $cephconfig = "/etc/pve/priv/ceph/${storeid}.conf";
if (-e $cephconfig) {
- $path .= ":conf=$cephconfig";
+ if ($pveceph_managed) {
+ warn "ignoring custom ceph config for storage '$storeid', 'monhost' is not set (assuming pveceph managed cluster)!\n";
+ } else {
+ $path .= ":conf=$cephconfig";
+ }
}
return ($path, $vmid, $vtype);
--
2.11.0
More information about the pve-devel
mailing list