Linux TOP命令 按内存占用排序和按CPU占用排序

1:在命令行提示符执行top命令


2:输入大写P,则结果按CPU占用降序排序。输入大写M,结果按内存占用降序排序。


另外:


认识top的显示结果


top命令的显示结果以下所示:


top - 01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48 Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie Cpu(s): 0.3% us, 1.0% sy, 0.0% ni, 98.7% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 191272k total, 173656k used, 17616k free, 22052k buffers Swap: 192772k total, 0k used, 192772k free, 123988k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd 14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top 1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init 2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0 3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0统计信息区 
前五行是系统总体的统计信息。第一行是任务队列信息,同 uptime 命令的执行结果。其内容以下:


01:06:48 当前时间 
up 1:22 系统运行时间,格式为时:分 
1 user 当前登陆用户数 
load average: 0.06, 0.60, 0.48 系统负载,即任务队列的平均长度。
三个数值分别为 1分钟、5分钟、15分钟前到如今的平均值。 


第2、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容以下:


Tasks: 29 total 进程总数 
1 running 正在运行的进程数 
28 sleeping 睡眠的进程数 
0 stopped 中止的进程数 
0 zombie 僵尸进程数 
Cpu(s): 0.3% us 用户空间占用CPU百分比 
1.0% sy 内核空间占用CPU百分比 
0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比 
98.7% id 空闲CPU百分比 
0.0% wa 等待输入输出的CPU时间百分比 
0.0% hi  
0.0% si  


最后两行为内存信息。内容以下:


Mem: 191272k total 物理内存总量 
173656k used 使用的物理内存总量 
17616k free 空闲内存总量 
22052k buffers 用做内核缓存的内存量 
Swap: 192772k total 交换区总量 
0k used 使用的交换区总量 
192772k free 空闲交换区总量 
123988k cached 缓冲的交换区总量。
内存中的内容被换出到交换区,然后又被换入到内存,但使用过的交换区还没有被覆盖,
该数值即为这些内容已存在于内存中的交换区的大小。
相应的内存再次被换出时可没必要再对交换区写入。 
进程信息区 
统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。


序号 列名 含义 
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 键能够选择显示的内容。按 f 键以后会显示列的列表,按 a-z 便可显示或隐藏对应的列,最后按回车键肯定。


按 o 键能够改变列的显示顺序。按小写的 a-z 能够将相应的列向右移动,而大写的 A-Z 能够将相应的列向左移动。最后按回车键肯定。


按大写的 F 或 O 键,而后按 a-z 能够将进程按照相应的列进行排序。而大写的 R 键能够将当前的排序倒转。缓存


/////app



%mem 内存使用率
virt 是虚拟内存
res是常驻内存
shr是共享内存


top命令下按f键能够看到详细说明
* A: PID        = Process Id
* E: USER       = User Name
* H: PR         = Priority
* I: NI         = Nice value
* O: VIRT       = Virtual Image (kb)
* Q: RES        = Resident size (kb)
* T: SHR        = Shared Mem size (kb)
* W: S          = Process Status
* K: %CPU       = CPU usage
* N: %MEM       = Memory usage (RES)
* M: TIME+      = CPU Time, hundredths
b: PPID       = Parent Process Pid
c: RUSER      = Real user name
d: UID        = User Id
f: GROUP      = Group Name
g: TTY        = Controlling Tty
j: P          = Last used cpu (SMP)
p: SWAP       = Swapped size (kb)
l: TIME       = CPU Time
r: CODE       = Code size (kb)
s: DATA       = Data+Stack size (kb)
u: nFLT       = Page Fault count
v: nDRT       = Dirty Pages count
y: WCHAN      = Sleeping in Function
z: Flags      = Task Flags <sched.h>
* X: COMMAND    = Command name/line


top命令下要查看某个用户启动的进程:先输入u,而后输入用户名,再回车


VIRT:virtual memory usage。Virtual这个词很神,通常解释是:virtual adj.虚的, 实质的, [物]有效的, 事实上的。究竟是虚的仍是实的?让Google给Define以后,将就明白一点,就是这东西仍是非物质的,可是有效果的,不发生在真实世界的,发生在软件世界的等等。这个内存使用就是一个应用占有的地址空间,只是要应用程序要求的,就全算在这里,而无论它真的用了没有。写程序怕出错,又不在意占用的时候,多开点内存也是很正常的。
RES:resident memory usage。常驻内存。这个值就是该应用程序真的使用的内存,但还有两个小问题,一是有些东西可能放在交换盘上了(SWAP),二是有些内存多是共享的。
SHR:shared memory。共享内存。就是说这一块内存空间有可能也被其余应用程序使用着;而Virt - Shr彷佛就是这个程序所要求的而且没有共享的内存空间。
DATA:数据占用的内存。若是top没有显示,按f键能够显示出来。这一块是真正的该程序要求的数据空间,是真正在运行中要使用的。


============================================


top里面描述进程内存使用量的数据来源于/proc/$pid/statm这个文件。经过观察kernel的代码就能弄清楚SHR,VIRT和RES这些数值的具体含义。


Linux经过一个叫作 task_statm 的函数来返回进程的内存使用情况


int task_statm(struct mm_struct *mm, int *shared, int *text,
int *data, int *resident)
{
*shared = get_mm_counter(mm, file_rss);
*text = (PAGE_ALIGN(mm->end_code) - (mm->start_code & PAGE_MASK))
>> PAGE_SHIFT;
*data = mm->total_vm - mm->shared_vm;
*resident = *shared + get_mm_counter(mm, anon_rss);
return mm->total_vm;
}
上面的代码中shared就是page cache里面实际使用了的物理内存的页数,text是代码所占用的页
数,data是总虚拟内存页数减去共享的虚拟内存页数,resident是全部在使用的物理内存的页
数。最后返回的mm->total_vm是进程虚拟内存的寻址空间大小。


函数get_mm_counter并不会作什么计算,它的功能是保证数值读取的原子性。


上面的数值最后会经过 procfs输出 到/proc/$pid/statm中去。他们与top显示的数值对应关系以下。


SHR: shared 
RES: resident 
VIRT: mm->total_vm 
CODE: code 
DATA: data


=======================================


o: VIRT (Virtual Image) - 进程使用的总虚拟内存 (virtual memory) 大小,包括进程的程序码、资料和共享程序库再加上被置换 (swap out) 的空间。VIRT = SWAP + RES 
p: SWAP (Swapped size) - 进程被置换的虚拟内存空间大小。 
q: RES (Resident size) - 进程非被置换的实体内存大小。RES = CODE + DATA 
r: CODE' (Code size) - 进程的程序码在实体内存佔用空间大小,亦叫做 text resident set (TRS)。 
s: DATA (Data+Stack size) - 进程佔用实体内存中的非程序码部份大小,亦叫做 data resident set (DRS)。 
t: SHR (Shared Mem size) - 进程使用的共享内存大小,便可以和其余进程共享的内存空间。 
n: %MEM (Memory usage) - 进程佔用实体内存大小对系统总实体内存大小的比例,以百分比显示。


ssh

相关文章
相关标签/搜索