[pve-devel] [PATCH v2 container 3/3] collect errors from all local volumes
Fabian Grünbichler
f.gruenbichler at proxmox.com
Mon Jul 11 12:03:36 CEST 2016
and then die with more meaningful/complete output, instead
of on the first encountered error.
---
src/PVE/LXC/Migrate.pm | 64 ++++++++++++++++++++++++++++++++------------------
1 file changed, 41 insertions(+), 23 deletions(-)
diff --git a/src/PVE/LXC/Migrate.pm b/src/PVE/LXC/Migrate.pm
index 83d2cb9..1c168bb 100644
--- a/src/PVE/LXC/Migrate.pm
+++ b/src/PVE/LXC/Migrate.pm
@@ -101,6 +101,15 @@ sub phase1 {
$self->{volumes} = []; # list of already migrated volumes
my $volhash = {}; # 'config', 'snapshot' or 'storage' for local volumes
+ my $volhash_errors = {};
+ my $abort = 0;
+
+ my $log_error = sub {
+ my ($msg, $volid) = @_;
+
+ $volhash_errors->{$volid} = $msg if !defined($volhash_errors->{$volid});
+ $abort = 1;
+ };
my $test_volid = sub {
my ($volid, $snapname) = @_;
@@ -113,13 +122,17 @@ sub phase1 {
my $scfg = PVE::Storage::storage_check_node($self->{storecfg}, $sid);
PVE::Storage::storage_check_node($self->{storecfg}, $sid, $self->{node});
- return if $scfg->{shared};
+ if ($scfg->{shared}) {
+ $self->log('info', "volume '$volid' is on shared storage '$sid'")
+ if !$snapname;
+ return;
+ }
$volhash->{$volid} = defined($snapname) ? 'snapshot' : 'config';
my ($path, $owner) = PVE::Storage::path($self->{storecfg}, $volid);
- die "can't migrate volume '$volid' - owned by other guest (owner = $owner)\n"
+ die "owned by other guest (owner = $owner)\n"
if !$owner || ($owner != $self->{vmid});
if (defined($snapname)) {
@@ -128,7 +141,7 @@ sub phase1 {
if (($scfg->{type} eq 'zfspool')) {
return;
}
- die "can't migrate snapshot of local volume '$volid'\n";
+ die "non-migratable snapshot exists\n";
}
};
@@ -144,17 +157,11 @@ sub phase1 {
return;
}
- my ($storage, $volname) = PVE::Storage::parse_volume_id($volid);
- my $scfg = PVE::Storage::storage_check_node($self->{storecfg}, $storage);
+ eval {
+ &$test_volid($volid, $snapname);
+ };
- if (!$scfg->{shared}) {
- $self->log('info', "copy mountpoint '$ms' ($volid) to node ' $self->{node}'")
- if !$snapname;
- } else {
- $self->log('info', "mountpoint '$ms' is on shared storage '$storage'")
- if !$snapname;
- }
- &$test_volid($volid, $snapname);
+ &$log_error($@, $volid) if $@;
};
# first unused / lost volumes owned by this container
@@ -192,19 +199,22 @@ sub phase1 {
# additional checks for local storage
foreach my $volid (keys %$volhash) {
- my ($sid, $volname) = PVE::Storage::parse_volume_id($volid);
- my $scfg = PVE::Storage::storage_config($self->{storecfg}, $sid);
+ eval {
+ my ($sid, $volname) = PVE::Storage::parse_volume_id($volid);
+ my $scfg = PVE::Storage::storage_config($self->{storecfg}, $sid);
- my $migratable = ($scfg->{type} eq 'dir') || ($scfg->{type} eq 'zfspool') ||
- ($scfg->{type} eq 'lvmthin') || ($scfg->{type} eq 'lvm');
+ my $migratable = ($scfg->{type} eq 'dir') || ($scfg->{type} eq 'zfspool') ||
+ ($scfg->{type} eq 'lvmthin') || ($scfg->{type} eq 'lvm');
- die "can't migrate '$volid' - storage type '$scfg->{type}' not supported\n"
- if !$migratable;
+ die "storage type '$scfg->{type}' not supported\n"
+ if !$migratable;
- # image is a linked clone on local storage, se we can't migrate.
- if (my $basename = (PVE::Storage::parse_volname($self->{storecfg}, $volid))[3]) {
- die "can't migrate '$volid' as it's a clone of '$basename'";
- }
+ # image is a linked clone on local storage, se we can't migrate.
+ if (my $basename = (PVE::Storage::parse_volname($self->{storecfg}, $volid))[3]) {
+ die "clone of '$basename'";
+ }
+ };
+ &$log_error($@, $volid) if $@;
}
foreach my $volid (sort keys %$volhash) {
@@ -219,6 +229,14 @@ sub phase1 {
}
}
+ foreach my $volid (sort keys %$volhash_errors) {
+ $self->log('warn', "can't migrate local volume '$volid': $volhash_errors->{$volid}");
+ }
+
+ if ($abort) {
+ die "can't migrate CT - check log\n";
+ }
+
foreach my $volid (keys %$volhash) {
my ($sid, $volname) = PVE::Storage::parse_volume_id($volid);
push @{$self->{volumes}}, $volid;
--
2.1.4
More information about the pve-devel
mailing list