top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。top
是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止。比较准确的说,top
命令提供了实时的对系统处理器的状态监视。它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用。内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.
top [参数]
显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等
-b
批处理-c
显示完整的治命令-I
忽略失效过程-s
保密模式-S
累积模式-i
<时间> 设置间隔时间-u
<用户名> 指定用户名-p
<进程号> 指定进程-n
<次数> 循环显示的次数命令:
top
输出:
top - 04:23:18 up 2:34, 2 users, load average: 0.00, 0.01, 0.05 Tasks: 115 total, 1 running, 114 sleeping, 0 stopped, 0 zombie %Cpu(s): 0.0 us, 0.3 sy, 0.0 ni, 99.7 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st KiB Mem : 999936 total, 603084 free, 144560 used, 252292 buff/cache KiB Swap: 2097148 total, 2097148 free, 0 used. 631400 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND zyiz 20 0 157676 2164 1528 R 0.7 0.2 0:00.10 top root 20 0 302436 6016 4648 S 0.3 0.6 1:07.99 vmtoolsd root 20 0 553156 18448 5792 S 0.3 1.8 0:04.25 tuned root 20 0 0 0 0 S 0.3 0.0 0:23.23 kworker/0:0 zyiz 20 0 142972 2332 1048 S 0.3 0.2 0:06.39 sshd root 20 0 128092 6708 3956 S 0.0 0.7 0:05.17 systemd root 20 0 0 0 0 S 0.0 0.0 0:00.01 kthreadd root 20 0 0 0 0 S 0.0 0.0 0:01.03 ksoftirqd/0 root rt 0 0 0 0 S 0.0 0.0 0:00.00 migration/0 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcu_bh root 20 0 0 0 0 S 0.0 0.0 0:03.06 rcu_sched root rt 0 0 0 0 S 0.0 0.0 0:00.68 watchdog/0 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 khelper root 20 0 0 0 0 S 0.0 0.0 0:00.00 kdevtmpfs root 0 -20 0 0 0 S 0.0 0.0 0:00.00 netns ......
说明:
统计信息区:
前五行是当前系统情况整体的统计信息区。下面我们看每一行信息的具体意义。
第一行,任务队列信息,同 uptime 命令的执行结果,具体参数说明情况如下:
04:23:18
— 当前系统时间up 2:34
— 系统已经运行了2小时34分钟(在这期间系统没有重启过!)2 users
— 当前有2
个用户登录系统load average: 0.00, 0.01, 0.05
— load average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。5
的时候就表明系统在超负荷运转了。第二行,Tasks — 任务(进程),具体信息说明如下:
系统现在共有115
个进程,其中处于运行中的有1
个,114
个在休眠(sleep),stoped状态的有0
个,zombie
状态(僵尸)的有0
个。
第三行,cpu
状态信息,具体属性说明如下:
0.0 us
— 用户空间占用CPU的百分比。0.3 sy
— 内核空间占用CPU的百分比。0.0 ni
— 改变过优先级的进程占用CPU的百分比99.7 id
— 空闲CPU百分比0.0 wa
— IO等待占用CPU的百分比0.0 hi
— 硬中断(Hardware IRQ)占用CPU的百分比0.0 si
— 软中断(Software Interrupts)占用CPU的百分比第四行,内存状态,具体信息如下:
第五行,swap交换分区信息,具体信息说明如下:
备注:第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。
如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free + 第四行的buffers + 第五行的cached,按这个公式此台服务器的可用内存。
对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
第六行,空行。
PID
— 进程idUSER
— 进程所有者PR
— 进程优先级NI
— nice值。负值表示高优先级,正值表示低优先级VIRT
— 进程使用的虚拟内存总量,单位kb
。VIRT=SWAP+RES
- RES
— 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
SHR
— 共享内存大小,单位kbS
— 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程%CPU
— 上次更新到现在的CPU时间占用百分比%MEM
— 进程使用的物理内存百分比TIME+
— 进程使用的CPU时间总计,单位1/100
秒COMMAND
— 进程名称(命令名/命令行)1.多U多核CPU监控
在top
基本视图中,按键盘数字“1
”,可监控每个逻辑CPU的状况:
观察上图,服务器有0
个逻辑CPU,实际上是1
个物理CPU。再按数字键1
,返回到top基本视图界面。
2.高亮显示当前运行进程
敲击键盘“b”(打开/关闭加亮效果),top
的视图变化如下:
如上图中,进程id
为9
,3211
的“top”进程被加亮了,top
进程就是视图第二行显示的唯一的运行态(runing)的那个进程,可以通过敲击“y”键关闭或打开运行态进程的加亮效果。
top
时,各进程是按照CPU的占用量来排序的,在下图中进程ID为32374
的python进程排在第一(cpu占用94%
),进程ID为653
的vmtools
进程排在第二(cpu占用2.0%
)。敲击键盘“x”(打开/关闭排序列的加亮效果),top的视图变化如下:
可以看到,top默认的排序列是“%CPU
”。
下图是按一次”shift + >
”的效果图,视图现在已经按照%MEM
来排序。
命令:
top -c
输出:
top - 09:38:06 up 3:23, 2 users, load average: 2.40, 2.19, 1.37 Tasks: 112 total, 4 running, 107 sleeping, 1 stopped, 0 zombie %Cpu(s): 97.2 us, 1.8 sy, 0.0 ni, 0.0 id, 0.0 wa, 0.0 hi, 1.1 si, 0.0 st KiB Mem : 999936 total, 74648 free, 130200 used, 795088 buff/cache KiB Swap: 2097148 total, 2097148 free, 0 used. 672960 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND zyiz 20 0 123156 4376 1904 R 42.5 0.4 10:45.19 python run+ zyiz 20 0 123152 4380 1908 R 42.5 0.4 1:38.90 python run+ root 20 0 302436 6024 4648 S 2.3 0.6 1:50.29 /usr/bin/v+ root 20 0 0 0 0 S 2.0 0.0 0:05.93 [kworker/u+ chrony 20 0 115848 1892 1496 S 1.7 0.2 0:00.53 /usr/sbin/+ root 20 0 34876 3152 2828 S 0.3 0.3 0:00.92 /usr/lib/s+ root 20 0 0 0 0 S 0.3 0.0 0:38.98 [kworker/0+ root 20 0 128092 6708 3956 S 0.0 0.7 0:05.51 /usr/lib/s+ root 20 0 0 0 0 S 0.0 0.0 0:00.02 [kthreadd] root 20 0 0 0 0 S 0.0 0.0 0:15.97 [ksoftirqd+ root rt 0 0 0 0 S 0.0 0.0 0:00.00 [migration+ root 20 0 0 0 0 S 0.0 0.0 0:00.00 [rcu_bh] root 20 0 0 0 0 R 0.0 0.0 0:07.42 [rcu_sched] root rt 0 0 0 0 S 0.0 0.0 0:05.48 [watchdog/+
命令:
top -b
命令:
top -S
命令:
top -n 2
说明:表示更新两次后终止更新显示
命令:
top -d 3
说明:表示更新周期为3秒
命令:
top -p 3237
top - 09:40:32 up 3:26, 2 users, load average: 3.07, 2.53, 1.62 Tasks: 1 total, 1 running, 0 sleeping, 0 stopped, 0 zombie %Cpu(s): 91.8 us, 2.4 sy, 0.0 ni, 0.0 id, 0.0 wa, 0.0 hi, 5.8 si, 0.0 st KiB Mem : 999936 total, 71276 free, 130352 used, 798308 buff/cache KiB Swap: 2097148 total, 2097148 free, 0 used. 672960 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND zyiz 20 0 123156 4376 1904 R 34.1 0.4 11:46.46 python
在 top
命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了s 选项, 其中一些命令可能会被屏蔽。
h
显示帮助画面,给出一些简短的命令总结说明k
终止一个进程。i
忽略闲置和僵死进程。这是一个开关式命令。q
退出程序r
重新安排一个进程的优先级别S
切换到累计模式s
改变两次刷新之间的延迟时间(单位为s
),如果有小数,就换算成m s
。输入0值则系统将不断刷新,默认值是5s
f
或者F
从当前显示中添加或者删除项目o
或者O
改变显示项目的顺序l
切换显示平均负载和启动时间信息m
切换显示内存信息t
切换显示进程和CPU状态信息c
切换显示命令名称和完整命令行M
根据驻留内存大小进行排序P
根据CPU使用百分比大小进行排序T
根据时间/累计时间进行排序W
将当前设置写入~/.toprc
文件中