我自从高中接触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人点赞
作者:LittleMagic
链接:https://www.jianshu.com/p/a6e96c102881
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。