How to Monitor Progress of (Copy/Backup/Compress) Data using ‘pv’ Command
When making backups, coping/moving large files on your Linux system, you may want to monitor the progress of an on going operation. Many terminal tools do not have the functionality to allow you to view progress information when a command is running in a pipe.
In this article, we shall look at an important Linux/Unix command called pv.
Pv is a terminal-based tool that allows you to monitor the progress of data that is being sent through a pipe. When using the pv command, it gives you a visual display of the following information:
- The time that has elapsed.
- The percentage completed including a progress bar.
- Shows current throughput rate.
- The total data transferred.
- and the ETA (estimated Time).
How to Install pv Command in Linux?
This command is not installed by default on most Linux distributions, therefore you can install it by following the steps below.
On Fedora, CentOS and RHEL
First you need to turn on EPEL repository and then run the following command.
# yum install pv # dnf install pv [On Fedora 22+ versions]
Dependencies Resolved ================================================================================= Package Arch Version Repository Size ================================================================================= Installing: pv x86_64 1.4.6-1.el7 epel 47 k Transaction Summary ================================================================================= Install 1 Package Total download size: 47 k Installed size: 93 k Is this ok [y/d/N]: y Downloading packages: pv-1.4.6-1.el7.x86_64.rpm | 47 kB 00:00:00 Running transaction check Running transaction test Transaction test succeeded Running transaction Installing : pv-1.4.6-1.el7.x86_64 1/1 Verifying : pv-1.4.6-1.el7.x86_64 1/1 Installed: pv.x86_64 0:1.4.6-1.el7 Complete!
On Debian, Ubuntu and Linux Mint
# apt-get install pv
Reading package lists... Done Building dependency tree Reading state information... Done The following NEW packages will be installed: pv 0 upgraded, 1 newly installed, 0 to remove and 533 not upgraded. Need to get 33.7 kB of archives. After this operation, 160 kB of additional disk space will be used. Get:1 http://archive.ubuntu.com/ubuntu/ trusty/universe pv amd64 1.2.0-1 [33.7 kB] Fetched 33.7 kB in 0s (48.9 kB/s) Selecting previously unselected package pv. (Reading database ... 216340 files and directories currently installed.) Preparing to unpack .../archives/pv_1.2.0-1_amd64.deb ... Unpacking pv (1.2.0-1) ... Processing triggers for man-db (18.104.22.168-1ubuntu1) ... Setting up pv (1.2.0-1) ...
On Gentoo Linux
Use emerge package manager to install pv command as shown.
# emerge --ask sys-apps/pv
On FreeBSD Linux
You can use the port to install it as follows:
# cd /usr/ports/sysutils/pv/ # make install clean
OR add the binary package as follows:
# pkg_add -r pv
How Do I use pv Command in Linux?
pv is mostly used with other programs which lack the ability to monitor the progress of a an ongoing operation. You can use it, by placing it in a pipeline between two processes, with the appropriate options available.
The standard input of pv will be passed through to its standard output and progress (output) will be printed on standard error. It has a similar behavior as the cat command in Linux.
The syntax of pv command as follows:
pv file pv options file pv file > filename.out pv options | command > filename.out comand1 | pv | command2
The options used with pv are divided into three categories, display switches, output modifiers and general options.
Some options under display modifiers.
- To turn on the display bar, use the -p option.
- To view the elapsed time, use the –timer option.
- To turn on ETA timer which tries to guess how long it will take before completion of an operation, use the –eta option. The guess is based on previous transfer rates and the total data size.
- To turn on a rate counter use the –rate option.
- To display the total amount of data transferred so far, use the –bytes option.
- To display progress inform of integer percentage instead of visual indication, use the -n option. This can be good when using pv with the dialog command to show progress in a dialog box.
Some options under output modifiers.
- To wait until the first byte is transferred before displaying progress information, use the –wait option.
- To assume the total amount of data to be transferred is SIZE bytes when computing percentage and ETA, use –size SIZE option.
- To specify seconds between updates, use the –interval SECONDS option.
- Use –force option to force an operation. This option forces pv to display visuals when standard error is not a terminal.
- The general options are –help to display usage information and –version to display version information.
Use pv Command with Examples
1. When no option is included, pv commands run with default -p, -t, -e, -r and -b options.
For example, to copy the opensuse.vdi file to /tmp/opensuse.vdi, run this command and watch the progress bar in screencast.
# pv opensuse.vdi > /tmp/opensuse.vdi
2. To make a zip file from your /var/log/syslog file, run the following command.
# pv /var/log/syslog | zip > syslog.zip
3. To count the number of lines, word and bytes in the /etc/hosts file while showing progress bar only, run this command below.
# pv -p /etc/hosts | wc
4. Monitor the progress of creating a backup file using tar utility.
# tar -czf - ./Downloads/ | (pv -p --timer --rate --bytes > backup.tgz)
5. Using pv and dialog terminal-based tool together to create a dialog progress bar as follows.
# tar -czf - ./Documents/ | (pv -n > backup.tgz) 2>&1 | dialog --gauge "Progress" 10 70
This is a good terminal-based tool that you can use with tools that do not have the ability, to monitor the progress of an operations such as coping/moving/backing up files, for more options check man pv.
I hope you find this article helpful and you can post a comment if you have any ideas to add about using pv command. And if you get any errors while using it, you can as well leave a comment.