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 [<ffffffff80168375>] poll_schedule_timeout+0x45/0x60 [<ffffffff8016994d>] do_sys_poll+0x49d/0x550 [<ffffffff80169abd>] SyS_poll+0x5d/0xf0 [<ffffffff804c16e7>] system_call_fastpath+0x16/0x1b [<00007f4a41ff2c1d>] 0x7f4a41ff2c1d [<ffffffffffffffff>] 0xffffffffffffffff
statm
/proc/[pid]/statm
显示进程所占用内存大小的统计信息,包含七个值,度量单位是page
(page
大小可通过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
当前运行的函数。
相关推荐
这个目录下的文件和子目录是系统内核与用户空间交互的一种方式,允许用户和管理员获取关于进程、内存、硬件设备、网络状态等实时信息。 1. **/proc文件系统概述** `/proc`目录中的每个文件和子目录都代表着一个...
在Linux环境下,用C++语言编写一个程序,以树状结构(即体现父子... 通过/proc目录获得各进程的父进程ppid,获得进程树的父亲表示,再将进程树的父亲表示转换成左孩子与右孩子,最后中序遍历二叉树,输出进程信息即可。
在应用层打印/proc文件系统的进程信息,并统计进程数
在 `/proc` 目录下,每个正在运行的进程都有一个以该进程的PID命名的子目录。这些子目录包含了与该进程相关的各种信息。例如: - **/proc/N/cmdline**: 显示进程启动时的命令行参数。 - **/proc/N/status**: 显示...
在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印
`/proc`目录下包含了很多以数字或名字命名的子目录,这些代表了系统中的每一个进程(PID)。每个子目录下又有很多文件,如`cmdline`, `status`, `exe`, `maps`, `fd`等,它们分别提供了进程的命令行参数、状态信息、...
/proc目录下的文件和子目录按照功能分为几大类:进程信息(如/proc/[pid])、系统信息(如/proc/cpuinfo、/proc/meminfo)、文件系统信息(如/proc/filesystems)、网络信息(如/proc/net/*)等。每个文件都对应了...
本教程将重点讲解如何在C语言环境下利用`/proc`进行程序设计,帮助开发者获取系统信息,监控进程状态,甚至对系统进行一定的配置和调整。 `/proc`目录下的文件和子目录反映了系统的实时状态。例如,每个运行中的...
- **进程信息**:以进程ID(PID)命名的子目录,如`/proc/1`,`/proc/2`等,每个目录下有多个文件,如`cmdline`, `status`, `exe`, `fd`等,用于展示对应进程的详细信息。 - **系统信息**:如`/proc/cpuinfo`提供...
在/Linux/proc/目录下,每个正在运行的进程都有一个以其PID(进程ID)命名的子目录。这些子目录包含了关于该进程的各种详细信息,如进程状态、打开的文件、内存使用情况等。例如,`/proc/<pid>/status`文件提供了...
proc(5)是 Linux 系统中的一个伪文件系统,它提供了进程信息的接口,挂载在/proc目录下。该目录下的文件大多数是只读的,但某些文件也允许内核变量被修改。 proc(5)的主要组成部分包括: 1. /proc/[number]/...
在`/proc`目录下,每个运行中的进程都有一个与其对应的子目录,其名称为进程ID(pid)。这个子目录下的文件提供了关于进程的各种详细信息: 1. **`/proc/pid/cmdline`**: 显示启动进程时的命令行参数。 2. **`/proc...
在`/proc`目录下,你可以找到以进程ID命名的子目录,每个子目录都包含了一些表示相应进程状态的文件。其中,`status`文件包含了进程的基本信息,包括内存使用情况。 打开`/proc/<pid>/status`文件,你可以看到类似...
Proc 文件系统中还包含了进程目录,每个进程都有一个对应的目录,以进程的 PID 号为目录名。进程目录的结构如下: * Cmdline:命令行参数 * Environ:环境变量值 * Fd:一个包含所有文件描述符的目录 * Mem:进程的...
/proc/self/:该目录提供了当前进程的信息,包括进程 ID、父进程 ID、进程状态等信息。 /proc/bus/:该目录提供了系统总线信息,包括 PCI 总线、ISA 总线、USB 总线等。 /proc/driver/:该目录提供了系统驱动程序...
1. **进程信息**:在/proc目录下,每个运行中的进程都有一个以进程ID命名的子目录。这些子目录包含如status、cmdline、exe等文件,分别提供了进程的状态、命令行参数和可执行文件的路径等信息。 2. **系统信息**:/...
Linux下取出进程目录的程序 g++ 利用 string来找,还有利用了/proc来找进程目录