博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
proc目录下的进程目录
阅读量:4159 次
发布时间:2019-05-26

本文共 4415 字,大约阅读时间需要 14 分钟。

Proc是一个虚拟文件系统,在Linux系统中它被挂载于/proc目录之上。Proc有多个功能 ,这其中包括用户可以通过它访问内核信息或用于排错,这其中一个非常有 用的功能,也是Linux变得更加特别的功能就是以文本流的形式来访问进程信息。很Linux命令(比如 ps、toPpstree等)都需要使用这个文件系统的信息。在/proc文件系统中,每一个进程都有一个相应的文件夹:/proc/pid,在该文件夹下会进程的相关信息

 

cmdline

/proc/[pid]/cmdline是一个只读文件,包含进程的完整命令行信息。如果这个进程是zombie进程,则这个文件没有任何内容。

comm

/proc/[pid]/comm是一个只读文件包含进程的命令名。

cwd

/proc/[pid]/cwd是进程当前工作目录的符号链接。

environ

/proc/[pid]/environ显示进程的环境变量。

exe

/proc/[pid]/exe为实际运行程序的符号链接。

fd

/proc/[pid]/fd是一个目录,包含进程打开文件的情况。

目录中的每一项都是一个符号链接,指向打开的文件,数字则代表文件描述符。

latency

/proc/[pid]/latency显示哪些代码造成的延时比较大(使用这个feature,需要执行“echo 1 > /proc/sys/kernel/latencytop”)。举例如下:

 

# cat /proc/2948/latency  Latency Top version : v0.1  30667 10650491 4891 poll_schedule_timeout do_sys_poll SyS_poll system_call_fastpath 0x7f636573dc1d  8 105 44 futex_wait_queue_me futex_wait do_futex SyS_futex system_call_fastpath 0x7f6365a167bc

每一行前三个数字分别是后面代码执行的次数,总共执行延迟时间(单位是微秒)和最长执行延迟时间(单位是微秒),后面则是代码完整的调用栈。

limits

/proc/[pid]/limits显示当前进程的资源限制。举例如下:

# cat /proc/2948/limits  Limit                     Soft Limit           Hard Limit           Units  Max cpu time              unlimited            unlimited            seconds  Max file size             unlimited            unlimited            bytes  Max data size             unlimited            unlimited            bytes  Max stack size            8388608              unlimited            bytes  Max core file size        0                    unlimited            bytes  Max resident set          unlimited            unlimited            bytes  Max processes             6409                 6409                 processes  Max open files            1024                 4096                 files  Max locked memory         65536                65536                bytes  Max address space         unlimited            unlimited            bytes  Max file locks            unlimited            unlimited            locks  Max pending signals       6409                 6409                 signals  Max msgqueue size         819200               819200               bytes  Max nice priority         0                    0  Max realtime priority     0                    0  Max realtime timeout      unlimited            unlimited            us

Soft Limit表示kernel设置给资源的值,Hard Limit表示Soft Limit的上限,而Units则为计量单元

maps

/proc/[pid]/maps显示进程的内存区域映射信息。举例如下:

# cat /proc/2948/maps  ......  address                   perms offset  dev   inode                      pathname  7f4a2e2ad000-7f4a2e2ae000 rw-p 00006000 08:14 6505977                    /usr/lib64/sasl2/libsasldb.so.3.0.0  7f4a2e2ae000-7f4a2e2af000 ---p 00000000 00:00 0  7f4a2e2af000-7f4a2eaaf000 rw-p 00000000 00:00 0                          [stack:94671]  7f4a2eaaf000-7f4a2eab0000 ---p 00000000 00:00 0  7f4a2eab0000-7f4a2f2b0000 rw-p 00000000 00:00 0                          [stack:94670]  ......  7f4a434d0000-7f4a434d5000 rw-p 0006e000 08:14 4292988                    /usr/sbin/libvirtd  7f4a4520a000-7f4a452f7000 rw-p 00000000 00:00 0                          [heap]  7ffd1a7e4000-7ffd1a805000 rw-p 00000000 00:00 0                          [stack]  7ffd1a820000-7ffd1a821000 r-xp 00000000 00:00 0                          [vdso]  ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0                  [vsyscall]

其中注意的一点是[stack:<tid>]是线程的堆栈信息,对应于/proc/[pid]/task/[tid]/路径。

root

/proc/[pid]/root是进程根目录的符号链接。

stack

/proc/[pid]/stack显示当前进程的内核调用栈信息,只有内核编译时打开了CONFIG_STACKTRACE编译选项,才会生成这个文件。举例如下:

# cat /proc/2948/stack  [
] poll_schedule_timeout+0x45/0x60 [
] do_sys_poll+0x49d/0x550 [
] SyS_poll+0x5d/0xf0 [
] system_call_fastpath+0x16/0x1b [<00007f4a41ff2c1d>] 0x7f4a41ff2c1d [
] 0xffffffffffffffff

statm

/proc/[pid]/statm显示进程所占用内存大小的统计信息,包含七个值,度量单位是pagepage大小可通过getconf PAGESIZE得到)。举例如下:

# cat /proc/2948/statm    72362 12945 4876 569 0 24665 0

各个值含义:

a)进程占用的总的内存;
b)进程当前时刻占用的物理内存;
c)同其它进程共享的内存;
d)进程的代码段;
e)共享库(从2.6版本起,这个值为0);
f)进程的堆栈;
g)dirty pages(从2.6版本起,这个值为0)。

syscall

/proc/[pid]/syscall显示当前进程正在执行的系统调用。举例如下:

# cat /proc/2948/syscall  7 0x7f4a452cbe70 0xb 0x1388 0xffffffffffdff000 0x7f4a4274a750 0x0 0x7ffd1a8033f0 0x7f4a41ff2c1d

第一个值是系统调用号(7代表poll),后面跟着6个系统调用的参数值(位于寄存器中),最后两个值依次是堆栈指针和指令计数器的值。如果当前进程虽然阻塞,但阻塞函数并不是系统调用,则系统调用号的值为-1,后面只有堆栈指针和指令计数器的值。如果进程没有阻塞,则这个文件只有一个“running”的字符串。

内核编译时打开了CONFIG_HAVE_ARCH_TRACEHOOK编译选项,才会生成这个文件。

wchan

/proc/[pid]/wchan显示当进程sleep时,kernel当前运行的函数。

转载地址:http://cabxi.baihongyu.com/

你可能感兴趣的文章
【5分钟代码练习】01—导航栏鼠标悬停效果的实现
查看>>
127个超级实用的JavaScript 代码片段,你千万要收藏好(中)
查看>>
127个超级实用的JavaScript 代码片段,你千万要收藏好(下)
查看>>
Flex 布局教程:语法篇
查看>>
年薪50万+的90后程序员都经历了什么?
查看>>
2019年哪些外快收入可达到2万以上?
查看>>
【JavaScript 教程】标准库—Date 对象
查看>>
前阿里手淘前端负责人@winter:前端人如何保持竞争力?
查看>>
【JavaScript 教程】面向对象编程——实例对象与 new 命令
查看>>
我在网易做了6年前端,想给求职者4条建议
查看>>
SQL1015N The database is in an inconsistent state. SQLSTATE=55025
查看>>
RQP-DEF-0177
查看>>
MySQL字段类型的选择与MySQL的查询效率
查看>>
Java的Properties配置文件用法【续】
查看>>
JAVA操作properties文件的代码实例
查看>>
java杂记
查看>>
RunTime.getRuntime().exec()
查看>>
Oracle 分组排序函数
查看>>
VMware Workstation 14中文破解版下载(附密钥)(笔记)
查看>>
日志框架学习
查看>>