In UNIX/Linux, “watch
” is a resourceful utility for monitoring updates in the specified command output (including errors) by refreshing the results every 2 seconds until it is interrupted using the “Ctrl+c” shortcut key.
It makes it easier for you to monitor the updates in background processes, disk usage, system uptime, tracking errors, and many more.
In this article, you will learn different ways to use the watch command, with practical examples.
Tutorial Details
Description | Watch |
Difficulty Level | Low |
Root or Sudo Privileges | No |
OS Compatibility | Ubuntu, Manjaro, Fedora, etc. |
Prerequisites | watch |
Internet Required | No |
Syntax of the Watch Command
The watch command takes two arguments: one is the option, and the other is the command (used as an argument to the watch command).
$ watch [OPTION] [COMMAND]
Monitoring the Command Output Changes
Monitor the output changes for a specific command (with or without flags) by specifying it as an argument to the watch command.
$ watch date
The above command will monitor the changes in the date command by updating the output every 2 seconds, as shown.
data:image/s3,"s3://crabby-images/effc3/effc3c41a1e4a7e40b3b007fa3ed1568e9c45866" alt="Monitoring the change in command output"
Setting a Custom Interval for Command Output Changes
Use the “-n
” flag to set a custom interval to update the command output used as an argument to the watch command.
$ watch -n 1 date
The above command will execute the date command every 1 second.
data:image/s3,"s3://crabby-images/f6928/f6928b05b0120594146ca2be866258c24fd9e7f6" alt="Change the time interval for watch command"
Highlighting the Difference in the Command Output Changes
The “-d
” flag will come in handy when multiple parameters are changing in the command output by highlighting each one of them when they change, as shown.
$ watch -d date
Output:
data:image/s3,"s3://crabby-images/a9b60/a9b60d7930a3a35ba881427bd1588101afbceac8" alt="Highlighting the command update changes"
Or, pass “cumulative
” as a value to the “-d
” flag if you want all the values that have ever changed to stay highlighted.
$ watch -d=cumulative date
Output:
data:image/s3,"s3://crabby-images/e1767/e17673799ae28d2c6ca9f9f05022a8cb1398d24e" alt="Keep the changed value highlighted"
Turning Off the Header
The “-t
” flag will remove the header from the watch command that contains the interval time, user-defined command, and current system time.
$ watch -t date
Output:
data:image/s3,"s3://crabby-images/7004e/7004e02b37818199798851079985695e0561cb3f" alt="Removing the watch command header from the command output"
Alerting When the Command Fails
The “-b
” flag will beep when the specified command used as an argument to the watch command returns an error or a non-zero exit status.
sudo apt install beep
” if it is not present.$ watch -b date
Output:
data:image/s3,"s3://crabby-images/d634e/d634ea31eb4d5a41f41eb3f04139655bdc2247f1" alt="Alert when the command return non-zero exit status"
Freezing When the Command Fails
The “-e
” flag will freeze the monitoring when the specified command used as an argument to the watch command fails or gets the non-zero exit status, asking you to press a key to exit.
In the following example, I’ve created a file with the name “file.txt
” that will be monitored using the watch and ls commands; when I remove that file, the monitoring will stop and ask for a key to press for quitting.
$ watch -e ls -l file.txt
Output:
data:image/s3,"s3://crabby-images/cc4d0/cc4d040c7234534144894d7f2b74fbd910d70246" alt="Freeze the watch command monitoring when the specified command fails"
Quit Monitoring When Command Output Changes
The “-g
” flag will quit monitoring for the specified command used as an argument to watch command on its first output change.
$ watch -g date
Output:
data:image/s3,"s3://crabby-images/ecf9a/ecf9abdb46c8ff97ee7712144a204c02a371543a" alt="Exit the command on its first update"
Monitoring the Multiple Piped Commands
If you want to monitor multiple commands piped together, enclose them in single or double quotes; otherwise, only the first command will get executed.
$ watch "ls -l | tail -n10; date"
Output:
data:image/s3,"s3://crabby-images/aeee9/aeee91737bbf7b1ddb6d9e4fbde700fc87261131" alt="Monitoring multiple commands piped together"
Exit Status
The watch command has eight exit statuses:
0
: Success.1
: Various Failures.2
: Forking the process to watch failed.3
: Replacing child process stdout with a write side pipe failed.4
: Command execution failed.5
: Closing child process write pipe failed.7
: IPC pipe creation failed.8
: The specified command exited on an error.
That’s all an informed Linux user should know about the watch command.
If you have any issue or question regarding this topic, then feel free to ask it in the comment section.
Join The Conversation
Users are always welcome to leave comments about the articles, whether they are questions, comments, constructive criticism, old information, or notices of typos. Please keep in mind that all comments are moderated according to our comment policy.