dd supports a 'status' flag, which enables it to show the copied bytes, duration, and the transfer rate, which then get printed to stderr.
Signed-off-by: Leo Nunner <l.nun...@proxmox.com> --- Changes from v1: - Add rate-limit for dd output with the intervals suggested by Thomas PVE/Storage.pm | 23 ++++++++++++++++++----- PVE/Storage/LVMPlugin.pm | 2 +- PVE/Storage/Plugin.pm | 4 ++-- 3 files changed, 21 insertions(+), 8 deletions(-) diff --git a/PVE/Storage.pm b/PVE/Storage.pm index c21b85e..dfceca9 100755 --- a/PVE/Storage.pm +++ b/PVE/Storage.pm @@ -821,12 +821,25 @@ sub storage_migrate { my $new_volid; my $pattern = volume_imported_message(undef, 1); - my $match_volid_and_log = sub { + # Matches new volid and rate-limits dd output + my $match_and_log = sub { my $line = shift; + my $show = 1; + + # rate-limit dd logs + if ($line =~ /(?:\d+ bytes)(?:.+?copied, )(\d+) s/) { + if ($1 < 60) { # if < 60s, print every 3s + $show = !($1 % 3); + } elsif($1 < 600) { # if < 10mins, print every 10s + $show = !($1 % 10); + } else { # else, print every 30s + $show = !($1 % 30); + } + } $new_volid = $1 if ($line =~ $pattern); - if ($logfunc) { + if ($logfunc && $show) { chomp($line); $logfunc->($line); } @@ -855,7 +868,7 @@ sub storage_migrate { # we won't be reading from the socket shutdown($socket, 0); - eval { run_command($cmds, output => '>&'.fileno($socket), errfunc => $logfunc); }; + eval { run_command($cmds, output => '>&'.fileno($socket), errfunc => $match_and_log); }; my $send_error = $@; # don't close the connection entirely otherwise the receiving end @@ -864,7 +877,7 @@ sub storage_migrate { # wait for the remote process to finish while (my $line = <$info>) { - $match_volid_and_log->("[$target_sshinfo->{name}] $line"); + $match_and_log->("[$target_sshinfo->{name}] $line"); } # now close the socket @@ -877,7 +890,7 @@ sub storage_migrate { die $send_error if $send_error; } else { push @$cmds, $recv; - run_command($cmds, logfunc => $match_volid_and_log); + run_command($cmds, logfunc => $match_and_log); } die "unable to get ID of the migrated volume\n" diff --git a/PVE/Storage/LVMPlugin.pm b/PVE/Storage/LVMPlugin.pm index a706e0c..4b951e7 100644 --- a/PVE/Storage/LVMPlugin.pm +++ b/PVE/Storage/LVMPlugin.pm @@ -645,7 +645,7 @@ sub volume_export { $size = int($1); }); PVE::Storage::Plugin::write_common_header($fh, $size); - run_command(['dd', "if=$file", "bs=64k"], output => '>&'.fileno($fh)); + run_command(['dd', "if=$file", "bs=64k", "status=progress"], output => '>&'.fileno($fh)); } sub volume_import_formats { diff --git a/PVE/Storage/Plugin.pm b/PVE/Storage/Plugin.pm index 8a41df1..e35fa97 100644 --- a/PVE/Storage/Plugin.pm +++ b/PVE/Storage/Plugin.pm @@ -1496,7 +1496,7 @@ sub volume_export { goto unsupported if $with_snapshots || $file_format eq 'subvol'; write_common_header($fh, $size); if ($file_format eq 'raw') { - run_command(['dd', "if=$file", "bs=4k"], output => '>&'.fileno($fh)); + run_command(['dd', "if=$file", "bs=4k", "status=progress"], output => '>&'.fileno($fh)); } else { run_command(['qemu-img', 'convert', '-f', $file_format, '-O', 'raw', $file, '/dev/stdout'], output => '>&'.fileno($fh)); @@ -1506,7 +1506,7 @@ sub volume_export { my $data_format = $1; goto unsupported if !$with_snapshots || $file_format ne $data_format; write_common_header($fh, $size); - run_command(['dd', "if=$file", "bs=4k"], output => '>&'.fileno($fh)); + run_command(['dd', "if=$file", "bs=4k", "status=progress"], output => '>&'.fileno($fh)); return; } elsif ($format eq 'tar+size') { goto unsupported if $file_format ne 'subvol'; -- 2.30.2 _______________________________________________ pve-devel mailing list pve-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel