top命令可以说是linux系统资源监控最常用的命令了,top 的输出格式为:
top - 20:29:19 up 83 days, 3:42, 2 users, load average: 7.96, 7.74, 6.15
Tasks: 214 total, 2 running, 212 sleeping, 0 stopped, 0 zombie
%Cpu(s): 50.3 us, 12.4 sy, 0.0 ni, 32.8 id, 0.0 wa, 0.0 hi, 4.5 si, 0.0 st
KiB Mem : 16267784 total, 5136976 free, 9050312 used, 2080496 buff/cache
KiB Swap: 6160380 total, 6005320 free, 155060 used. 5676356 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
28509 root 20 0 9.912g 1.812g 7964 S 524.3 11.7 4998:59 java
16168 root 20 0 15.625g 5.199g 18020 S 4.0 33.5 233:32.50 java
28 root 20 0 0 0 0 S 0.3 0.0 3:02.31 ksoftirqd/4
33 root 20 0 0 0 0 S 0.3 0.0 2:26.09 ksoftirqd/5
43 root 20 0 0 0 0 S 0.3 0.0 4:56.15 ksoftirqd/7
552 root 20 0 0 0 0 R 0.3 0.0 36:56.82 xfsaild/dm-0
以上面的输出格式为例,逐行说明。
top - 20:29:19 up 83 days, 3:42, 2 users, load average: 7.96, 7.74, 6.15
Tasks: 214 total, 2 running, 212 sleeping, 0 stopped, 0 zombie
%Cpu(s): 50.3 us, 12.4 sy, 0.0 ni, 32.8 id, 0.0 wa, 0.0 hi, 4.5 si, 0.0 st
第三行主要描述系统cpu的占用情况:
KiB Mem : 16267784 total, 5136976 free, 9050312 used, 2080496 buff/cache
第四行描述的是系统的内存使用情况(以kb为单位):
KiB Swap: 6160380 total, 6005320 free, 155060 used. 5676356 avail Mem
第五行描述的是交换分区情况:
在默认情况下,仅显示比较重要的 PIO、USERPR、NI、VIRT、RES、SHR、S、%CPU、%MEMTIME+、COMMAND列。
要想展示隐藏项,按 f 键进入选择界面,左侧有 * 号的表示该项是展示状态,通过方向键上下移动到某项,按 d 键可以改变该项的展示状态,然后按【ESC】或【q】键退出返回top界面。
* PID = Process Id
* USER = Effective User Name
* PR = Priority
* NI = Nice Value
* VIRT = Virtual Image (KiB)
* RES = Resident Size (KiB)
* SHR = Shared Memory (KiB)
* S = Process Status
* %CPU = CPU Usage
* %MEM = Memory Usage (RES)
* TIME+ = CPU Time, hundredths
* COMMAND = Command Name/Line
PPID = Parent Process pid
UID = Effective User Id
RUID = Real User Id
RUSER = Real User Name
SUID = Saved User Id
SUSER = Saved User Name
GID = Group Id
GROUP = Group Name
PGRP = Process Group Id
TTY = Controlling Tty
TPGID = Tty Process Grp Id
SID = Session Id
nTH = Number of Threads
P = Last Used Cpu (SMP)
TIME = CPU Time
SWAP = Swapped Size (KiB)
CODE = Code Size (KiB)
DATA = Data+Stack (KiB)
nMaj = Major Page Faults
nMin = Minor Page Faults
nDRT = Dirty Pages Count
WCHAN = Sleeping in Function
Flags = Task Flags <sched.h>
CGROUPS = Control Groups
SUPGIDS = Supp Groups IDs
SUPGRPS = Supp Groups Names
TGID = Thread Group Id
ENVIRON = Environment vars
vMj = Major Faults delta
vMn = Minor Faults delta
USED = Res+Swap Size (KiB)
nsIPC = IPC namespace Inode
nsMNT = MNT namespace Inode
nsNET = NET namespace Inode
nsPID = PID namespace Inode
nsUSER = USER namespace Inode
nsUTS = UTS namespace Inode
各列的含义:
序号 | 列名 | 含义 |
---|---|---|
a | PID | 进程ID |
b | PPID | 父进程ID |
c | RUSER | 真实用户名 |
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 |
top命令可以后缀不同的参数,从而实现特定目的。
在top界面,可以通过一些指令实时改变显示内容(区分大小写):