Signed-off-by: Alexandre Derumier <aderum...@odiso.com>
---
 PVE/QemuMigrate.pm | 57 +++++++++++++++++++++++++++-------------------
 1 file changed, 33 insertions(+), 24 deletions(-)

diff --git a/PVE/QemuMigrate.pm b/PVE/QemuMigrate.pm
index 6243d0d..5063b7b 100644
--- a/PVE/QemuMigrate.pm
+++ b/PVE/QemuMigrate.pm
@@ -559,34 +559,12 @@ sub phase2 {
 
     start_remote_tunnel($self, $nodename, $migration_type, $raddr, $rport, 
$ruri);
 
+    livemigrate_storage($self, $vmid);
+
     my $start = time();
 
     my $opt_bwlimit = $self->{opts}->{bwlimit};
 
-    if (defined($self->{online_local_volumes})) {
-       $self->{storage_migration} = 1;
-       $self->{storage_migration_jobs} = {};
-       $self->log('info', "starting storage migration");
-
-       die "The number of local disks does not match between the source and 
the destination.\n"
-           if (scalar(keys %{$self->{target_drive}}) != scalar 
@{$self->{online_local_volumes}});
-       foreach my $drive (keys %{$self->{target_drive}}){
-           my $target = $self->{target_drive}->{$drive};
-           my $nbd_uri = $target->{nbd_uri};
-
-           my $source_drive = PVE::QemuServer::parse_drive($drive, 
$conf->{$drive});
-           my $target_drive = PVE::QemuServer::parse_drive($drive, 
$target->{drivestr});
-
-           my $source_sid = 
PVE::Storage::Plugin::parse_volume_id($source_drive->{file});
-           my $target_sid = 
PVE::Storage::Plugin::parse_volume_id($target_drive->{file});
-
-           my $bwlimit = PVE::Storage::get_bandwidth_limit('migration', 
[$source_sid, $target_sid], $opt_bwlimit);
-
-           $self->log('info', "$drive: start migration to $nbd_uri");
-           PVE::QemuServer::qemu_drive_mirror($vmid, $drive, $nbd_uri, $vmid, 
undef, $self->{storage_migration_jobs}, 1, undef, $bwlimit);
-       }
-    }
-
     $self->log('info', "starting online/live migration on $ruri");
     $self->{livemigration} = 1;
 
@@ -1121,4 +1099,35 @@ sub start_remote_tunnel {
     }
 }
 
+sub livemigrate_storage {
+    my ($self, $vmid) = @_;
+
+    my $conf = $self->{vmconf};
+    my $opt_bwlimit = $self->{opts}->{bwlimit};
+
+    if (defined($self->{online_local_volumes})) {
+       $self->{storage_migration} = 1;
+       $self->{storage_migration_jobs} = {};
+       $self->log('info', "starting storage migration");
+
+       die "The number of local disks does not match between the source and 
the destination.\n"
+           if (scalar(keys %{$self->{target_drive}}) != scalar 
@{$self->{online_local_volumes}});
+       foreach my $drive (keys %{$self->{target_drive}}){
+           my $target = $self->{target_drive}->{$drive};
+           my $nbd_uri = $target->{nbd_uri};
+
+           my $source_drive = PVE::QemuServer::parse_drive($drive, 
$conf->{$drive});
+           my $target_drive = PVE::QemuServer::parse_drive($drive, 
$target->{drivestr});
+
+           my $source_sid = 
PVE::Storage::Plugin::parse_volume_id($source_drive->{file});
+           my $target_sid = 
PVE::Storage::Plugin::parse_volume_id($target_drive->{file});
+
+           my $bwlimit = PVE::Storage::get_bandwidth_limit('migration', 
[$source_sid, $target_sid], $opt_bwlimit);
+
+           $self->log('info', "$drive: start migration to $nbd_uri");
+           PVE::QemuServer::qemu_drive_mirror($vmid, $drive, $nbd_uri, $vmid, 
undef, $self->{storage_migration_jobs}, 1, undef, $bwlimit);
+       }
+    }
+}
+
 1;
-- 
2.20.1

_______________________________________________
pve-devel mailing list
pve-devel@pve.proxmox.com
https://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel

Reply via email to