设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 手机 数据 公司
当前位置: 首页 > 服务器 > 搭建环境 > Windows > 正文

如何监控Linux服务器状态?

发布时间:2019-06-14 00:34 所属栏目:117 来源:佚名
导读:Linux 服务器我们天天打交道,特别是 Linux 工程师更是如此。为了保证服务器的安全与性能,我们经常需要监控服务器的一些状态,以保证工作能顺利开展。 本文介绍的几个命令,不仅仅适用于服务器监控,也适用于我们日常情况下的开发。 1、watch watch 命令

如何监控Linux服务器状态?

Linux 服务器我们天天打交道,特别是 Linux 工程师更是如此。为了保证服务器的安全与性能,我们经常需要监控服务器的一些状态,以保证工作能顺利开展。

本文介绍的几个命令,不仅仅适用于服务器监控,也适用于我们日常情况下的开发。

1、watch

watch 命令我们的使用频率很高,它的基本作用是,按照指定频率重复执行某一条指令。使用这个命令,我们可以重复调用一些命令来达到监控服务器的作用。

默认情况下,watch 命令的执行周期是 2 秒,但我们可以使用 -n 选项来指定运行频率,比如我们想要每隔 5 秒执行 date 命令,可以这么执行:

  1. $ watch -n 5 date 

一台服务器肯定有多人在用,特别是本部门的小伙伴。对于这些小伙伴有没浑水摸鱼,我们可以使用一些命令来监控他们。

我们可以每隔 10 秒执行 who 命令,来看看都有谁在使用服务器。

  1. $ watch -n 10 who  
  2. Every 10.0s: who                             butterfly: Tue Jan 23 16:02:03 2019  
  3. shs      :0           2019-01-23 09:45 (:0)  
  4. dory     pts/0        2019-01-23 15:50 (192.168.0.5)  
  5. alvin     pts/1        2019-01-23 16:01 (192.168.0.15)  
  6. shark    pts/3        2019-01-23 11:11 (192.168.0.27) 

如果发现系统运行很慢,我们可以调用 uptime 命令来查看系统平均负载情况。

  1. $ watch uptime  
  2. Every 2.0s: uptime                           butterfly: Tue Jan 23 16:25:48 2019  
  3.  16:25:48 up 22 days,  4:38,  3 users,  load average: 1.15, 0.89, 1.02 

一些关键的进程肯定不能挂,否则可能会影响到业务开展,所以我们可以重复统计服务器中的所有进程数量。

  1. $ watch -n 5 'ps -ef | wc -l'  
  2. Every 5.0s: ps -ef | wc -l                   butterfly: Tue Jan 23 16:11:54 2019  
  3. 245 

想动态知道服务器内存使用情况,可以重复执行 free 命令。

  1. $ watch -n 5 free -m  
  2. Every 5.0s: free -m                          butterfly: Tue Jan 23 16:34:09 2019  
  3.               total        used        free      shared  buff/cache   available  
  4. Mem:           5959         776        3276          12        1906        4878  
  5. Swap:          2047           0        2047 

当然不仅仅是这些,我们还可以重复调用很多命令来对服务器一些关键参数进行监控,

2、top

使用 top 命令我们可以知道系统的很多关键参数,而且是动态更新的。默认情况下,top 监控的是系统的整体状态,如果我们只想知道某个人的使用情况,可以使用 -u 选项来指定这个人。

  1. $ top -u alvin  
  2. top - 16:14:33 up 2 days,  4:27,  3 users,  load average: 0.00, 0.01, 0.02  
  3. Tasks: 199 total,   1 running, 198 sleeping,   0 stopped,   0 zombie  
  4. %Cpu(s):  0.0 us,  0.2 sy,  0.0 ni, 99.8 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st  
  5. MiB Mem :   5959.4 total,   3277.3 free,    776.4 used,   1905.8 buff/cache  
  6. MiB Swap:   2048.0 total,   2048.0 free,      0.0 used.   4878.4 avail Mem  
  7.   PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND  
  8. 23026 alvin      20   0   46340   7820   6504 S   0.0   0.1   0:00.05 systemd  
  9. 23033 alvin      20   0  149660   3140     72 S   0.0   0.1   0:00.00 (sd-pam)  
  10. 23125 alvin      20   0   63396   5100   4092 S   0.0   0.1   0:00.00 sshd  
  11. 23128 alvin      20   0   16836   5636   4284 S   0.0   0.1   0:00.03 zsh 

在这个结果里,你不仅仅可以看到 alvin 这个用户运行的所有的进程数,也可以看到每个进程所消耗的系统资源(CPU,内存),同时依然可以看到整个系统的关键参数。

3、ac

如果你想知道每个用户登录服务器所使用的时间,你可以使用 ac 命令。这个命令需要你安装 acct 包(Debian)或 psacct 包(RHEL,Centos)。

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读