0 前言
top命令是Unix 和 Linux下常用的性能分析工具,提供了一个动态的、交互式的实时视图,显示系统的整体性能信息,以及正在运行的进程的相关信息,包括各个进程的资源占用状况,类似于Windows的任务管理器。
1 top命令 格式、选项和操作
1.1 top命令 格式
[purpleendurer @ bash ~] top --help
top: inappropriate '-help'
Usage:
top -hv | -bcHiOSs -d secs -n max -u|U user -p pid(s) -o field -w [cols]
[purpleendurer @ bash ~]
top -hv | -bcHiOSs -d secs -n max -u|U user -p pid(s) -o field -w [cols]
1.2 top命令选项
选项 | 功能 |
---|---|
-b | 以批处理(batch)模式运行,直接将结果输出到文件。 |
-c | 显示完整的命令行而不截断。 |
-d <秒数> | 指定 top 命令的刷新时间间隔,单位为秒。 |
-H | 在进程信息中显示线程详细信息。 |
-i | 不显示闲置(idle)或无用的进程。 |
-n <次数> | 指定 top 命令运行的次数后自动退出。 |
-p <进程ID> | 仅显示指定进程ID的信息。 |
-S | 累计显示进程的 CPU 使用时间。 |
-u <用户名> -U <用户名> |
仅显示指定用户名的进程信息。 |
1.3 top命令操作说明
top命令提供了动态的、交互式的实时视图,可以进行以下操作:
操作 | 说明 |
---|---|
Ctrl+L | 擦除并且重写屏幕 |
K | 终止一个进程。 系统将提示用户输入需要终止的进程PID,以及需要给该进程发送什么样的信号。 默认值是信号15。一般的终止进程可以使用15信号。如果不能正常结束那就使用信号9强制结束该进程。 在安全模式中此命令被屏蔽。 |
i | 忽略闲置和僵死进程。这是一个开关式命令。 |
q | 退出程序 |
r | 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。 输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。 |
S | 切换到累计模式。 |
s | 改变两次刷新之间的延迟时间。 系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。 输入0值则系统将不断刷新,默认值是5 s。 需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。 |
f或者F | 从当前显示中添加或者删除项目。 |
o或者O | 改变显示项目的顺序 |
l | 切换显示平均负载和启动时间信息。 |
m | 切换显示内存信息。 |
t | 切换显示进程和CPU状态信息。 |
c | 切换显示命令名称和完整命令行。 |
M | 根据驻留内存大小进行排序。 |
P | 根据CPU使用百分比大小进行排序。 |
T | 根据时间/累计时间进行排序。 |
W | 将当前设置写入~/.toprc文件中。 |
2 top命令实例
top - 23:49:06 up 3 min, 0 users, load average: 0.01, 0.03, 0.00
Tasks: 5 total, 1 running, 4 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.2 us, 0.0 sy, 0.0 ni, 99.7 id, 0.0 wa, 0.2 hi, 0.0 si, 0.0 st
KiB Mem : 3855948 total, 2028368 free, 257300 used, 1570280 buff/cache
KiB Swap: 0 total, 0 free, 0 used. 3350552 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 csdn 20 0 40356 5120 3748 S 0.0 0.1 0:00.19 zsh
46 csdn 20 0 40156 5112 3844 S 0.0 0.1 0:00.03 zsh
72 csdn 20 0 40156 5024 3780 S 0.0 0.1 0:00.03 zsh
100 csdn 20 0 15124 3540 3124 S 0.0 0.1 0:00.00 bash
114 csdn 20 0 59472 4176 3640 R 0.0 0.1 0:00.00 top
显示的信息比较丰富,我们逐行分析说明。
第一行:系统当前状态
1.系统时间:23:48:30
2.运行时间:up 3 min,
3.当前登录用户:0 users
4.负载均衡(uptime) load average: 0.01, 0.03, 0.00
average后面的三个数分别是1分钟、5分钟、15分钟的负载情况。
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。
如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了
备注:第一行信息内容 同 uptime 命令的执行结果相同
第二行:任务(进程)队列信息 Tasks
1.总进程数量 :5 total
2.运行进程数量:1 running
3.休眠进程数量:4 sleeping
4.停止进程数量:0 stopped
5.僵尸进程数量:0 zombie
第三行:cpu状态信息 %Cpu(s)
1.用户空间占用CPU的百分比(user space) :0.8% us
2.内核空间占用CPU的百分比(sysctl) :0.2% sy
3.改变过优先级的进程占用CPU的百分比( nice) :0.0% ni
4.空闲CPU百分比(idolt) :99.0% id
5.IO等待占用CPU的百分比(wait) :0.0% wa
6.硬中断占用CPU的百分比(Hardware IRQ) :0.0% hi
7.软中断占用CPU的百分比(Software Interrupts) :0.0% si
8.被虚拟化程序偷取的 CPU 时间百分比(steal) :0.0 st
第四行:内存状态 KiB Mem
1.内存总量 :3855948 total
2.未用内存数量 :2028368 free
3.已用内存数量 :257300 used
4.缓存的内存量 :1570280 buff/cache
第五行:交换分区信息 swap
1.总量 :0 total
2.未用 :0 free
3.已用 :0 used
4.利用内存:3350552 avail Mem
第六行:空行
第七行以下:各进程(任务)的状态监控
1.PID: 进程id
2.USER : 进程所有者
3.PR : 进程优先级
4. NI:nice值。负值表示高优先级,正值表示低优先级
5.VIRT(virtual memory usage 虚拟内存):进程使用的虚拟内存总量,包括进程使用的代码(code)、数据(data)、共享库(shared libraries),以及被换出(swap out)到交换区和映射了(map)但尚未使用(未载入实体内存)的部分等,单位kb。VIRT=SWAP+RES
6.RES(resident memory usage 常驻内存):进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
7.SHR(shared memory 共享内存):共享内存大小,单位kb
8.S:进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
9.%CPU :上次更新到现在的CPU时间占用百分比
10.%MEM:进程使用的物理内存百分比
11.TIME+ :进程使用的CPU时间总计,单位1/100秒
12. COMMAND:进程运行的命令(命令名/命令行)
注:计算某个进程所占的物理内存大小公式:RES – SHR