您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件开发专栏 > 系统/运维 > 正文

监控Linux服务器活动的几个命令

发表于:2019-02-13 作者:Sandra Henry-stocker 来源:Linux中国

watchtop 和 ac 命令为我们监视 Linux 服务器上的活动提供了一些十分高效的途径。

为了在获取系统活动时更加轻松,Linux 系统提供了一系列相关的命令。在这篇文章中,我们就一起来看看这些对我们很有帮助的命令吧。

watch 命令

watch 是一个用来轻松地重复检测 Linux 系统中一系列数据命令,例如用户活动、正在运行进程、登录、内存使用等。这个命令实际上是重复地运行一个特定的命令,每次都会重写之前显示的输出,它提供了一个比较方便的方式用以监测在你的系统中发生的活动。

首先以一个基础且不是特别有用的命令开始,你可以运行 watch -n 5 date,然后你可以看到在终端中显示了当前的日期和时间,这些数据会每五秒更新一次。你可能已经猜到了,-n 5 选项指定了运行接下来一次命令需要等待的秒数。默认是 2 秒。这个命令将会一直运行并按照指定的时间更新显示,直到你使用 ^C 停下它。


  1. Every5.0s:datebutterfly:WedJan2315:59:142019
  2.  
  3. WedJan2315:59:14EST2019

下面是一个更有趣的命令实例,你可以监控一个在服务器中登录用户的列表,该列表会按照指定的时间定时更新。就像下面写到的,这个命令会每 10 秒更新一次这个列表。登出的用户将会从当前显示的列表中消失,那些新登录的将会被添加到这个表格当中。如果没有用户再登录或者登出,这个表格跟之前显示的将不会有任何不同。


  1. $watch-n10who
  2.  
  3. Every10.0s:whobutterfly:TueJan2316:02:032019
  4.  
  5. shs:02019-01-2309:45(:0)
  6. dory pts/02019-01-2315:50(192.168.0.5)
  7. nemo pts/12019-01-2316:01(192.168.0.15)
  8. shark pts/32019-01-2311:11(192.168.0.27)

如果你只是想看有多少用户登录进来,可以通过 watch 调用 uptime 命令获取用户数和负载的平均水平,以及系统的工作状况。


  1. $watchuptime
  2.  
  3. Every2.0s:uptimebutterfly:TueJan2316:25:482019
  4.  
  5. 16:25:48up22days,4:38,3users,load average:1.15,0.89,1.02

如果你想使用 watch 重复一个包含了管道的命令,就需要将该命令用引号括起来,就比如下面这个每五秒显示一次有多少进程正在运行的命令。


  1. $watch-n5'ps -ef | wc -l'
  2.  
  3. Every5.0s:ps-ef|wc-l butterfly:TueJan2316:11:542019
  4.  
  5. 245

要查看内存使用,你也许会想要试一下下面的这个命令组合:


  1. $watch-n5free-m
  2.  
  3. Every5.0s:free-m butterfly:TueJan2316:34:092019
  4.  
  5. Every5.0s:free-m butterfly:TueJan2316:34:092019
  6.  
  7. total used free shared buff/cache available
  8. Mem:595977632761219064878
  9. Swap:204702047

你可以在 watch 后添加一些选项查看某个特定用户下运行的进程,不过 top 为此提供了更好的选择。

top 命令

如果你想查看某个特定用户下的进程,top 命令的 -u 选项可以很轻松地帮你达到这个目的。


  1. $top-u nemo
  2. top-16:14:33up2days,4:27,3users,load average:0.00,0.01,0.02
  3. Tasks:199total,1running,198sleeping,0stopped,0zombie
  4. %Cpu(s):0.0us,0.2sy,0.0ni,99.8id,0.0wa,0.0hi,0.0si,0.0st
  5. MiBMem:5959.4total,3277.3free,776.4used,1905.8buff/cache
  6. MiBSwap:2048.0total,2048.0free,0.0used.4878.4availMem
  7.  
  8. PID USER PR NI VIRT RES SHR S%CPU%MEM TIME+COMMAND
  9. 23026nemo2004634078206504S0.00.10:00.05systemd
  10. 23033nemo200149660314072S0.00.10:00.00(sd-pam)
  11. 23125nemo2006339651004092S0.00.10:00.00sshd
  12. 23128nemo2001683656364284S0.00.10:00.03zsh

你可能不仅可以看到某个用户下的进程,还可以查看每个进程所占用的资源,以及系统总的工作状况。

ac 命令

如果你想查看系统中每个用户登录的时长,可以使用 ac 命令。运行该命令之前首先需要安装 acct(Debian 等)或者 psacct(RHEL、Centos 等)包。

ac 命令有一系列的选项,该命令从 wtmp 文件中拉取数据。这个例子展示的是最近用户登录的总小时数。


  1. $ ac
  2. total1261.72

这个命令显示了用户登录的总的小时数:


  1. $ ac-p
  2. shark5.24
  3. nemo5.52
  4. shs1251.00
  5. total1261.76

这个命令显示了每天登录的用户小时数:


  1. $ ac-d|tail-10
  2.  
  3. Jan11total0.05
  4. Jan12total1.36
  5. Jan13total16.39
  6. Jan15total55.33
  7. Jan16total38.02
  8. Jan17total28.51
  9. Jan19total48.66
  10. Jan20total1.37
  11. Jan22total23.48
  12. Todaytotal9.83

总结

Linux 系统上有很多命令可以用于检查系统活动。watch 命令允许你以重复的方式运行任何命令,并观察输出有何变化。top 命令是一个专注于用户进程的最佳选项,以及允许你以动态方式查看进程的变化,还可以使用 ac 命令检查用户连接到系统的时间。