top命令

  • Post author:
  • Post category:其他


我自从高中接触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 -c



top -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

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。