top使用参数详解

linux下的top命令参数说明 (virt,res,shr,data 的意义)

%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键能够显示出来。这一块是真正的该程序要求的数据空间,是真正在运行中要使用的。

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

sleep是让线程去睡觉,它释放资源,让CPU切换到别的线程的执行,会消耗切换时间。

      感受仍是wait*系列函数更好一些
       由于能够在完成相同功能的状况占用更少的CPU资源,实时性要好一些。
      好比串口通信的握手过程,使用Wait*系列函数,能够发送完毕后设置超值为30秒,当是当有数据到达时以当即中止等待,处理数据。
      若是使用Sleep只能有两种方法,循环执行多个短期的Sleep,或者Sleep(30000)。若是前一种状况由于在循环,因此会占用CPU资源。若是有后一种方法,当数据在30内到达时将会反应迟钝。

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

        linux中利用pthread库作多线程编程,若是使用简单的sleep系统调用,若是对pthread的实现不是很清楚的话,或者linux内核的sleep系统调用和pthread库配合的不是很好的话,在线程里面进行sleep系统调用的话,可能致使全部的线程休眠。或者在main函数里面调用sleep,在特定版本的linux内核中可能致使程序全部线程都休眠。这多是不但愿的,因此能够用异步IO实现“安全”的线程休眠。具体用select实现便可:

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) - 进程佔用实体内存大小对系统总实体内存大小的比例,以百分比显示。
linux

相关文章
相关标签/搜索