[Linux]top指令的学习和使用
参数含义
top - 10:21:50 up 5 days, 20:33, 2 users, load average: 0.42, 0.39, 0.41
Tasks: 3123 total, 1 running, 3122 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.2 us, 0.1 sy, 0.0 ni, 99.7 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 36202515+total, 25721084+free, 34356148 used, 70458160 buff/cache
KiB Swap: 16777212 total, 16777212 free, 0 used. 28670643+avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
19518 oracle 20 0 11.013g 430624 218128 S 5.6 0.1 191:30.62 ora_dia0_orcl1
15574 root rt 0 1330780 181500 110224 S 5.2 0.1 362:13.55 osysmond.bin
17070 oracle 20 0 31.080g 120004 19052 S 1.6 0.0 195:04.48 ora_dia0_cdbtes
96997 root 20 0 160908 5480 1576 R 1.6 0.0 0:00.55 top
统计信息区前五行是系统整体的统计信息。第一行是任务队列信息,同 uptime 命令的执行结果。其内容如下:
- 10:21:50 时间
- up 5 days, 20:33 机器启动以来的事件
- 2 users 当前登录用户数
- load average: 0.42, 0.39, 0.41 系统负载,即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。
第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:
- total 进程总数
- running 正在运行的进程数
- sleeping 睡眠的进程数
- stopped 停止的进程数
- zombie 僵尸进程数
- 0.2 us 用户空间占用CPU百分比
- 0.1 sy 内核空间占用CPU百分比
- 0.0 ni 用户进程空间内改变过优先级的进程占用CPU百分比
- 99.7 id 空闲CPU百分比
- 0.0 wa 等待输入输出的CPU时间百分比
- 0.0 hi 硬件CPU中断占用百分比
- 0.0 si 软中断占用百分比
- 0.0 st 虚拟机占用百分比
最后两行为内存信息。内容如下:
KiB Mem:
- 36202515+total 物理内存总量
- 25721084+free 空闲内存总量
- 34356148 used 使用的物理内存总量
- 70458160 buff/cache 用作内核缓存的内存量
KiB Swap:
- 16777212 total 交换区总量
- 16777212 free 空闲交换区总量
- 0 used 使用的交换区总量
- 28670643+avail Mem 缓冲的交换区总量,内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小,相应的内存再次被换出时可不必再对交换区写入。
进程信息区统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。
序号 | 列名 | 含义 |
---|---|---|
a | PID | 进程id |
b | PPID | 父进程id |
c | RUSER | Real user name |
d | UID | 进程所有者的用户id |
e | USER | 进程所有者的用户名 |
f | GROUP | 进程所有者的组名 |
g | TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
h | PR | 优先级 |
i | NI | nice值。负值表示高优先级,正值表示低优先级 |
j | P | 最后使用的CPU,仅在多CPU环境下有意义 |
k | %CPU | 上次更新到现在的CPU时间占用百分比 |
l | TIME | 进程使用的CPU时间总计,单位秒 |
m | TIME+ | 进程使用的CPU时间总计,单位1/100秒 |
n | %MEM | 进程使用的物理内存百分比 |
o | VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |
p | SWAP | 进程使用的虚拟内存中,被换出的大小,单位kb。 |
q | RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |
r | CODE | 可执行代码占用的物理内存大小,单位kb |
s | DATA | 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb |
t | SHR | 共享内存大小,单位kb |
u | nFLT | 页面错误次数 |
v | nDRT | 最后一次写入到现在,被修改过的页面数。 |
w | S | 进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程) |
x | COMMAND | 命令名/命令行 |
y | WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
z | Flags | 任务标志,参考 sched.h |
默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通过下面的快捷键来更改显示内容。
命令使用
网上很多资料显示:按f,然后通过 a-z 对每一列进行控制,但是我对 procps-ng version 3.3.10 版本以上的测试结果,这个操作逻辑已经不再适用。
f 进入 Fields Management,在这个界面下, |按键|功能| |—|—-| |a|切换默认窗口(Def,Job,Mem,Usr),不同的窗口显示的项不一样,默认的排序字段也不同| |up|向上切换展示项| |down|向下切换展示项| |d|是否展示项| |s|以当前项为排序|
更多指令:
|按键|功能|
|—|—-|
|Ctrl+L|擦除并且重写屏幕|
|R|反转排序结果|
|shift+<|向左改变序列|
|shift+>|向右改变序列|
|x|高亮排序列|
|b|高亮当前进程|
|