top命令

我自从高中接触Ubuntu开始就知道了top命令,工作以来更是没少使用它,但从来没有为它写过一篇总结。今天比较累,这种文章又不费脑子,就顺手写一写吧。

通俗点说,Linux中的top命令就像是Windows中的任务管理器。它会以列表的形式展示出系统的当前状态以及进程信息,并且定时刷新,同时也支持一些交互性的操作。

直接执行top命令,就会看到如下界面。

top命令的界面

下面逐行解释这些内容代表什么含义。

  • 第一行:概况
    HH:mm:ss:当前的系统时间。
    up xxx days, HH:mm:从本次开机到现在经过的时间。
    x user:当前有几个用户登录到该机器。
    load average:系统1分钟、5分钟、15分钟内的平均负载值。
    平均负载的详细含义和算法内容很丰富,请暂时参考这里

  • 第二行:进程计数(Tasks)
    total:进程总数。
    running:正在运行的进程数,对应状态TASK_RUNNING。
    sleeping:睡眠的进程数,对应状态TASK_INTERRUPTIBLE和TASK_UNINTERRUPTIBLE。
    stopped:停止的进程数,对应状态TASK_STOPPED。
    zombie:僵尸进程数,对应状态TASK_ZOMBIE。
    既然已经提到了Linux下的进程状态,干脆直接复习一下进程状态的转换吧。

Linux进程状态转换图

复习完了继续看。

  • 第三行:CPU使用率(%Cpu(s))
    us:进程在用户空间(user)消耗的CPU时间占比,不包含调整过优先级的进程。
    sy:进程在内核空间(system)消耗的CPU时间占比。
    ni:调整过用户态优先级的(niced)进程的CPU时间占比。
    id:空闲的(idle)CPU时间占比。
    wa:等待(wait)I/O完成的CPU时间占比。
    hi:处理硬中断(hardware interrupt)的CPU时间占比。
    si:处理软中断(software interrupt)的CPU时间占比。
    st:当Linux系统是在虚拟机中运行时,等待CPU资源的时间(steal time)占比。

  • 第四、五行:物理内存和交换空间(Mem/Swap)
    以物理内存为例。free命令也会打印出类似的信息。
    total:内存总量。
    free:空闲内存量。
    used:使用中的内存量。
    buff/cache:缓存和page cache占用的内存量。

  • 以下所有行:进程详细信息
    这里显示的数据列是可以改的,默认会显示如图中的12列。其含义分别如下:
    PID:进程ID。
    USER:进程所有者的用户名。
    PR:从系统内核角度看的进程调度优先级。
    NI:进程的nice值,即从用户空间角度看的进程优先级。值越低,优先级越高。
    VIRT:进程申请使用的虚拟内存量。
    RES:进程使用的驻留内存(即未被swap out的内存)量。
    SHR:进程使用的共享内存量。
    S:进程状态。R=running,S=interruptible sleeping,D=uninterruptible sleeping,T=stopped,Z=zombie。
    %CPU:进程在一个更新周期内占用的CPU时间比例。
    %MEM:进程占用的物理内存比例。
    TIME+:进程创建后至今占用的CPU时间长度。
    COMMAND:运行进程使用的命令。

在top命令的界面中,可以输入一些指令实现交互性的操作,下面列出一些比较常用的交互性操作。

  • CTRL+L:刷新整个屏幕,重新开始显示。
  • h:显示帮助。
  • q:退出top程序。
  • 空格:立即刷新信息。
  • k:杀掉进程。输入k之后,会提示用户输入PID及要发送哪种信号。
  • r:重新设置进程优先级,即renice。输入r之后,会提示用户输入PID及新的nice值。
  • s:改变刷新周期。输入s之后,会提示用户输入新的刷新周期,单位为秒。
  • n:改变进程列表中的显示数量。
  • f:添加或删除进程列表中的列。输入f之后会显示字母与列的映射表,再输入对应字母就可以开关相应的列。
  • c:在COMMAND列中切换显示命令名和完整的命令行。
  • u:指定在进程列表中只显示对应用户的进程。
  • l:切换显示界面中第一行信息(时间和平均负载)。
  • t:切换显示界面中第二、三行信息(进程和CPU统计)。
  • m:切换显示界面中第四、五行信息(内存和交换空间)。
  • 1:切换展开CPU统计信息。展开后,会分别显示CPU每个逻辑核心的占用。
  • N:按PID对进程排序。
  • M:按%MEM对进程排序。
  • P:按%CPU对进程排序。
  • T:按TIME+对进程排序。
  • H:切换在进程列表中显示所有线程信息。

其中,有一些参数可以直接跟在top命令后来使用,比如top -ctop -H等。另外还有一个top -p,用来指定PID显示。由于它支持逗号分隔的多个PID,因此用法很灵活,如以下示例:

~ top -p `pgrep java | tr "\\n" "," | sed 's/,$//'`
top - 23:05:45 up 203 days,  8:41,  1 user,  load average: 0.90, 0.97, 0.95
Tasks:   9 total,   0 running,   9 sleeping,   0 stopped,   0 zombie
%Cpu(s):  2.8 us,  0.7 sy,  0.0 ni, 96.4 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem : 26392654+total, 18476940 free, 49103776 used, 19634582+buff/cache
KiB Swap:        0 total,        0 free,        0 used. 20935299+avail Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
 3324 yarn      20   0 3602148 1.387g  24792 S   5.6  0.6   7573:31 java
 3328 hbase     20   0 33.585g 0.031t  29228 S   0.9 12.7   1421:30 java
16662 kafka     20   0 14.885g 1.248g  28528 S   0.9  0.5 542:21.35 java
 2996 hdfs      20   0 3205040 1.218g  23040 S   0.5  0.5   1818:30 java
 4635 flume     20   0 7130040 506148  32136 S   0.5  0.2 118:52.33 java
18295 yarn      20   0 10.162g 595760  41136 S   0.5  0.2   0:36.26 java
18296 yarn      20   0 10.151g 564780  41132 S   0.5  0.2   0:35.63 java
18294 yarn      20   0 10.155g 570528  41136 S   0.0  0.2   0:35.22 java
18301 yarn      20   0 10.162g 559228  41136 S   0.0  0.2   0:37.29 java

20人点赞

操作系统/Linux/运维



作者:LittleMagic
链接:https://www.jianshu.com/p/a6e96c102881
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值