Linux top命令用于实时显示 process 的动态。
使用权限:所有使用者。
语法
top [选项]
选项:
-d 秒数:指定 top 命令每隔几秒更新。默认是 3 秒;
-b:使用批处理模式输出。一般和”-n”选项合用,用于把 top 命令重定向到文件中;
-n 次数:指定 top 命令执行的次数。一般和”-“选项合用;
-p 进程PID:仅查看指定 ID 的进程;
-s:使 top 命令在安全模式中运行,避免在交互模式中出现错误;
-u 用户名:只监听某个用户的进程;
-q : 没有任何延迟的进行刷新,如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行;
-c : 切换显示模式,共有两种模式,一是只显示执行档的名称,另一种是显示完整的路径与名称S : 累积模式,会将己完成或消失的子行程 ( dead child process ) 的 CPU time 累积起来;
-i : 不显示任何闲置 (idle) 或僵死 (zombie) 的行程
在 top 命令的显示窗口中,还可以使用如下按键进行交互操作:
h:显示帮助画面,给出一些简短的命令总结说明
k: 终止一个进程。
i: 忽略闲置和僵死进程。这是一个开关式命令。
q: 退出程序
r: 重新安排一个进程的优先级别
S: 切换到累计模式
s: 改变两次刷新之间的延迟时间(单位为s
f:或者F 从当前显示中添加或者删除项目
o或者O: 改变显示项目的顺序
l: 切换显示平均负载和启动时间信息
m:切换显示内存信息
t: 切换显示进程和CPU状态信息
c: 切换显示命令名称和完整命令行
M:根据驻留内存大小进行排序
P: 根据CPU使用百分比大小进行排序
T: 根据时间/累计时间进行排序
W:将当前设置写入~/.toprc文件中
q:退出 top 命令;
一、TOP前五行统计信息
统计信息区前五行是系统整体的统计信息。
第一行为任务队列信息
top - 12:08:29【当前时间】 up 343 days, 14:59【系统运行时间】, 2 users【当前登录用户数】, load average: 0.00, 0.01, 0.05【系统负载】
系统负载,即任务队列的平均长度。 三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。如果 CPU 是单核的,则这个数值超过 1 就是高负载:如果 CPU 是四核的,则这个数值超过 4 就是高负载
第二行为进程信息
Tasks: 72 total【进程总数】, 1 running【正在运行的进程数】, 70 sleeping【睡眠的进程数】, 1 stopped【停止的进程数】, 0 zombie【僵尸进程数】
第三行为CPU的信息
%Cpu(s): 0.3 us【用户空间占用CPU百分比】, 0.3 sy【内核空间占用CPU百分比】, 0.0 ni【改变过优先级的进程占用CPU的百分比】, 99.3 id【空闲CPU百分比】, 0.0 wa【IO等待占用CPU的百分比】, 0.0 hi【硬中断(Hardware IRQ)占用CPU的百分比】, 0.0 si【软中断(Software Interrupts)占用CPU的百分比】, 0.0 st【虚拟时间百分比】
当有多个CPU时,这些内容可能会不止一行。
st(steal time)意为虚拟时间百分比,就是当有虚拟机时,虚拟 CPU 等待实际 CPU 的时间百分比
第四行为物理内存使用信息
KiB Mem : 1883724 total【物理内存总量】, 126704 free【空闲内存总量】, 827496 used【使用的物理内存总量】, 929524 buff/cache【用作内核缓存的内存量】
第五行为虚拟内存使用(交换空间) 信息
KiB Swap: 0 total【交换区总量】, 0 free【空闲交换区总量】, 0 used【使用的交换区总量】. 882208 avail Mem 【缓冲的交换区总量】
缓冲(buffer)和(cache)的区别:
缓存(cache)是在读取硬盘中的数据时,把最常用的数据保存在内存的缓存区中,再次读取该数据时,就不去硬盘中读取了,而在缓存中读取。
缓冲(buffer)是在向硬盘写入数据时,先把数据放入缓冲区,然后再一起向硬盘写入,把分散的写操作集中进行,减少磁盘碎片和硬盘的反复寻道,从而提高系统性能。
简单来说,缓存(cache)是用来加速数据从硬盘中”读取”的,而缓冲(buffer)是用来加速数据”写入”硬盘的。
可用内存=free + buffer + cached
对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
二、进程信息
PID【进程id】 USER【进程所有者的用户名】 PR【优先级】 NI【nice值】 VIRT【进程使用的虚拟内存总量】 RES【进程使用的、未被换出的物理内存大小】 SHR【共享内存大小】 S【进程状态】 %CPU【上次更新到现在的CPU时间占用百分比】 %MEM【进程使用的物理内存百分比】 TIME+【进程使用的CPU时间总计】 COMMAND【命令名/命令行】
更多列信息如下表所示。
列名
含义
PID
进程id
PPID
父进程id
RUSER
Real user name
UID
进程所有者的用户id
USER
进程所有者的用户名
GROUP
进程所有者的组名
TTY
启动进程的终端名。不是从终端启动的进程则显示为 ?
PR
优先级
NI
nice值。负值表示高优先级,正值表示低优先级
P
最后使用的CPU,仅在多CPU环境下有意义
%CPU
上次更新到现在的CPU时间占用百分比
TIME
进程使用的CPU时间总计,单位秒
TIME+
进程使用的CPU时间总计,单位1/100秒
%MEM
进程使用的物理内存百分比
VIRT
进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
SWAP
进程使用的虚拟内存中,被换出的大小,单位kb。
RES
进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
CODE
可执行代码占用的物理内存大小,单位kb
DATA
可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
SHR
共享内存大小,单位kb
nFLT
页面错误次数
nDRT
最后一次写入到现在,被修改过的页面数。
S
进程状态。 D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程
COMMAND
命令名/命令行
WCHAN
若该进程在睡眠,则显示睡眠中的系统函数名
Flags
任务标志,参考 sched.h
其他
# 监控java线程数
ps -eLf | grep java | wc -l
# 监控网络客户连接数
netstat -n | grep tcp | grep 侦听端口 | wc -l
Reference
本作品采用《CC 协议》,转载必须注明作者和本文链接