命令行生存指南:监视命令输出

系统 Linux
有时候需要不断的执行某个命令并追踪其输出产生的变化情况。一种常见的方法是通过写一段死循环的 shell 脚本来实现,不过 Linux 本身已经提供了一个工具来帮你定期执行指定的程序并将结果全屏输出,本节将会介绍该工具。

[[349673]]

操作概述

有时候需要不断的执行某个命令并追踪其输出产生的变化情况。一种常见的方法是通过写一段死循环的 shell 脚本来实现,不过 Linux 本身已经提供了一个工具来帮你定期执行指定的程序并将结果全屏输出,本节将会介绍该工具。

概念和术语

在 shell 上执行一个命令行时通常会自动打开三个标准文件,即标准输入文件(stdin),通常对应终端的键盘;标准输出文件(stdout)和标准错误输出文件(stderr),这两个文件都对应终端的屏幕。进程将从标准输入文件中得到输入数据,将正常输出数据输出到标准输出文件,而将错误信息送到标准错误文件中。

操作实战

场景一:使用 watch 定期执行命令并监视输出

难度
演示用发行版 Ubuntu
涉及命令 watch
watch 的基本用法

watch 的使用方法很简单,只需要: 

  1. watch 命令

就行了,这样 watch 命令会每隔两秒执行一次 命令,并全屏输出执行结果。

下图是执行 watch date 的一个界面: 

  1. Every 2.0s: date orangepipc2: Sat Oct 3 09:55:14 2020
  2.  
  3. Sat 03 Oct 2020 09:55:14 AM CST

图中第一行中的 Every 2.0s: 表示 watch 每隔 2 秒执行一次命令。后面的 date 为要执行的命令。再后面的 orangepipc2: 是执行命令的主机名,Sat Oct 3 09:55:14 2020 为执行命令的时间。

从第三行开始就是命令执行的输出结果。

指定重复执行命令的间隔时间

通过 -n 间隔 你也可以设置重复执行命令的间隔时间,比如我可以调整为每 5 秒中执行一次 date 命令

  1. watch -n 5 date
发现输出中的变化

如果只是单纯的重复执行命令的话,那么可以很容易地通过 shell 循环来实现,然而 watch 的能力不仅如此而已。

通过 -d 选项,watch 还能高亮显示两次输出中不同的部分,这个功能相当实用: 

  1. watch -d -n 10 date

 

除了高亮显示输出中改变的部分外,你也可以设置让 watch 发现结果有改变时退出循环执行,方法是使用 -g/--chgexit 选项。例如我们可以通过下面命令来发现 USB 变动情况。 

  1. watch -g 'dmesg |grep -i usb |tail'
检测命令执行的返回值

默认情况下,watch 并不会关心命令的执行结果是否成功,但你可以设置让 watch 检测命令的返回值,当命令运行返回非 0 时发出蜂鸣(-b/--beep)或者直接退出(-e/--errexit)。

  1. watch -e wrong_commands

 

小练习

  • 尝试使用 watch 监控工程目录,并结合其他工具实现自动编译。

 

 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2020-11-05 09:30:59

命令行Linux

2020-11-22 06:20:53

命令行Linux

2013-05-21 14:58:08

系统监视glances开源

2023-08-12 11:40:11

命令行生存

2020-07-30 13:34:48

终端命令行Linux

2014-08-25 16:23:24

2023-03-31 08:44:55

Go开发命令

2009-12-25 16:04:06

shell命令行

2020-12-10 16:16:08

工具代码开发

2020-12-11 06:44:16

命令行工具开发

2015-07-01 09:15:46

linuxQuora命令行

2009-12-09 09:25:52

Linux命令行svn命令

2015-11-25 14:03:29

LinuxMop股票

2009-12-23 14:14:09

Linux高级命令行

2011-05-17 10:28:57

VMwareXenServer

2022-12-30 08:30:28

Linux命令行json

2012-02-08 16:37:36

ibmdw

2023-06-09 07:45:29

Kuberneteskubectl

2010-07-15 10:47:22

Perl命令行

2009-12-24 14:51:39

Linux命令行
点赞
收藏

51CTO技术栈公众号