Linux /proc/pid目录下相应文件的信息说明和含义

Proc 是一个虚拟文件系统,在Linux 系统中它被挂载于/proc 目录之上。Proc 有多个功能  ,这其中包括用户可以通过它访问内核信息或用于排错,这其中一个非常有  用的功能,也是Linux 变得更加特别的功能就是以文本流的形式来访问进程信息。很Linux 命令( 比如 ps toPpstree ) 都需要使用这个文件系统的信息。注意, 本文就是向用户介绍一些访问这些信息的方法  。需要说明的是,本文所述的内容并不  一定适用所有内核版本,有部分操作只适用于2.6 内核。
一、进程信息
/proc 文件系统中,每一个进程都有一个相应的文件  。下面是/proc 目录下的一些重要文件 
/proc/pid/cmdline  包含了用于开始进程的命令 
/proc/pid/cwd 包含了当前进程工作目录的一个链接 
/proc/pid/environ  包含了可用进程环境变量的列表 
/proc/pid/exe  包含了正在进程中运行的程序链接;
/proc/pid/fd/  这个目录包含了进程打开的每一个文件的链接;
/proc/pid/mem  包含了进程在内存中的内容;
/proc/pid/stat 包含了进程的状态信息;
/proc/pid/statm  包含了进程的内存使用信息。
下面是一些获取进程信息的例子:
  假设现在要查看是否所有的进程都会做存储器清除工作。在/proc/pid/stat 文件中的每一  个进程标识 ( 8 个属性) 提供了有关进程的很多  “个人”信  息。这个信  息可以对每一个  进程标识进行。
0x00000002 Process being created
0x00000004 Exiting
0x00000008 Dead
0x00000040 Process using
superuser privflage
0x00000200  P rocess dumping core
0x00000400 Prooess received some signal
0x00000800  Process allocating memory
0x00001000 Killed due to out-of--memory condition
笔者从/usr/src/linux/include/linux/sched.h  中提取了这些信息。
 /proc/pid/fd/  目录提供  了有关打开文件的信息。要查看被进程使用的输入文件,使用以下命令
# ls –l /proc/pid/fd/0
   查看被进程使用socket ,使用以下命令 
#ls –l /proc/pid/fd|sed –n `/socket/{s/.*
//;s/
//p}`
有关这些socket 的信息可以使用以下命令获取 
# netstat --ae
  要将命令行参数传递给任意进程,使用以下命令 
~~cat /proc/pid/cmdline
    获取某一进程父进程的ID 号,使用以下命令:
#grep PPid/proc/pid/status
二、普通的系统信息
Proc 包含了很多系统信息,这其中包括CPU 负载、文件系统和网络配置  。下面是一些通过Proc 查看和更改系统的例子:
  获取可用系统内存的空间 
# grep  Free /proc/meminfo
  自从系统最后一次启动后的系统统计可以从/proc/stat 文件中获取 
#grep processes /proc/stat
  获知第 1 5 15 分钟系统负载的平均值 
#awk `{print “1 min:\t” $1 “\n5 min:\t” $2 “\n15 min:\t” $3}` /proc/loadavg
 /proc/partitions 可用于获取系统的分区信息 
 /proc/net /proc/sys/net 可用于查看和更改重要的网络信息。比如,禁用ping 命令,可以以root 身份运行以下命令 
#echo 1>/proc/sys/net/ipv4/icmp_echo_ignore_all
如果要启用IP 转发/IP 伪装,使用以下命令 
#echo 1> /proc/sys/net/ipv4/ip_forward
  已经挂载的文件系统信息可以从/proc/mounts 中检索。
  要改变正在使用的主机名  ,使用以下命令:
# echo www.abc.corn >/proc/sys/kernel/hostname
  要获取CPU 信息,使用以下命令 
# cat /proc/cpuinfo
  要获知swap 空间的使用情况  ,使用以下命令:
# cat /proc/swaps
  获取系统的正常运行时间:
#cat /proc/uptime
  列出由NFS 共享的文件系统:
# cat /proc/fs/nfsd/exports
三、相关内核的信息
这是一个非常宽泛的主题,这里只介绍其中一小部分内容:
  从正在运行的内核中获知内核的版本:
#cat /proc/version
 /proc/kmsg 文件被作为内核日志信息源,它可以被作为一个系统信息调用的接口使用。
 /proc/kcore 文件提供了以内核文件格式形式访问系统物理内存,并且可以被gdb 用于检查任意内核数据结构的当前状态。如果装了源码,那么可以通过查看/usr/src/linux/Documentation/filesystems/proc.txt 文件来获取更多的信息 
从中可以看出来,Proc 是一个非常不错的获取系统信息渠道。如果利用得好,则它对Linux 系统的维护和管理能提供非常大的帮助。

【各个文件含义】
/proc 是一个伪文件系统, 被用作内核数据结构的接口, 而不仅仅是解释说明/dev/kmem.
/proc 里的大多数文件都是只读的, 但也可以通过写一些文件来改变内核变量.
(

Linux 内核提供了一种通过 /proc 文件系统,在运行时访问内核内部数据结构、改变内核设置的机制proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。

用户和应用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。由于系统的信息,如进程,是动态改变的,所以用户或应用程序读取proc文件时,proc文件系统是动态从系统内核读出所需信息并提交的。下面列出的这些文件或子文件夹,并不是都是在你的系统中存在,这取决于你的内核配置和装载的模块。另外,在/proc下还有三个很重要的目录:net,scsi和sys。 Sys目录是可写的,可以通过它来访问或修改内核的参数,而net和scsi则依赖于内核配置。例如,如果系统不支持scsi,则scsi 目录不存在。

除了以上介绍的这些,还有的是一些以数字命名的目录,它们是进程目录。系统中当前运行的每一个进程都有对应的一个目录在/proc下,以进程的 PID号为目录名,它们是读取进程信息的接口。而self目录则是读取进程本身的信息接口,是一个link。

)


下面对整个 /proc 目录作一个大略的介绍.

[number]
在 /proc 目录里, 每个正在运行的进程都有一个以该进程 ID 命名的子目录, 其下包括如下的目录和伪文件:
[number] /cmdline
该文件保存了进程的完整命令行. 如果该进程已经被交换出内存, 或者该进程已经僵死, 那么就没有任何东西在该文件里, 这时候对该文件的读操作将返回零个字符. 该文件以空字符 null 而不是换行符作为结束标志.
[number] /cwd
一个符号连接, 指向进程当前的工作目录. 例如, 要找出进程 20 的 cwd, 你可以:
cd /proc/20/cwd; /bin/pwd
请注意 pwd 命令通常是 shell 内置的, 在这样的情况下可能工作得不是很好(casper 注: pwd 只能显示 /proc/20/cwd, 要是想知道它的工作目录,直接ls -al /proc/20不就好了).
[number] /environ
该文件保存进程的环境变量, 各项之间以空字符分隔, 结尾也可能是一个空字符. 因此, 如果要输出进程 1 的环境变量, 你应该:
(cat /proc/1/environ; echo) | tr ";\000"; ";\n";
(至于为什么想要这么做, 请参阅 lilo(8).)
[number] /exe
也是一个符号连接, 指向被执行的二进制代码. 在 Linux 2.0 或者更早的版本下, 对 exe 特殊文件的 readlink(2) 返回一个如下格式的字符串: [设备号]:节点号
举个例子, [0301]:1502 就是某设备的 1502 节点, 该设备的主设备号为 03 (如 IDE, MFM 等驱动器), 从设备号为 01 (第一个驱动器的第一分区). 而在 Linux 2.2 下, readlink(2) 则给出命令的实际路径名. 另外, 该符号连接也可以正常析引用(试图打开 exe 文件实际上将打开一个可执行文件). 你甚至可以键入 /proc/[number]/exe 来运行 [number] 进程的副本. 带 -inum 选项的 find(1) 命令可以定位该文件.
[number] /fd
进 程所打开的每个文件都有一个符号连接在该子目录里, 以文件描述符命名, 这个名字实际上是指向真正的文件的符号连接,(和 exe 记录一样).例如, 0 是标准输入, 1 是标准输出, 2 是标准错误, 等等. 程序有时可能想要读取一个文件却不想要标准输入,或者想写到一个文件却不想将输出送到标准输出去,那么就可以很有效地用如下的办法骗过(假定 -i 是输入文件的标志, 而 -o 是输出文件的标志):
foobar -i /proc/self/fd/0 -o /proc/self/fd/1 ...
这 样就是一个能运转的过滤器. 请注意该方法不能用来在文件里搜索, 这是因为 fd 目录里的文件是不可搜索的. 在 UNIX 类的系统下, /proc/self/fd/N 基本上就与 /dev/fd/N 相同. 实际上, 大多数的 Linux MAKEDEV 脚本都将 /dev/fd 符号连接到 [..]/proc/self/fd 上.
]
 

 

attr:

进程的属性

 

cmdline:

启动进程时执行的命令

 

cwd:

指向进程当前工作目录的软

 ll cwd可知是个软连接。

 

environ:

进程执行时使用的环境变量,文件内容使用null字节('\0')分隔,然后以null字节结束。因此获取进程使用的环境变量使用如下:

(cat /proc/pid/environ; echo) | tr '\000' '\n'

 

fd:

 此目录包含进程打开的所有文件,文件名为文件描述符,目录中每个软连接都会指向进程打开的实际文件。

 比如:nginx下:

root@iZ23onhpqvwZ:/proc/22210/fd# ll
total 0
dr-x------ 2 root root 0 Oct 20 17:39 ./
dr-xr-xr-x 9 root root 0 Oct 20 17:22 ../
lrwx------ 1 root root 64 Oct 20 17:39 0 -> /dev/null
lrwx------ 1 root root 64 Oct 20 17:39 1 -> /dev/null
lrwx------ 1 root root 64 Oct 20 17:39 10 -> socket:[2917559817]
l-wx------ 1 root root 64 Oct 20 17:39 2 -> /opt/nginx/logs/error.log
l-wx------ 1 root root 64 Oct 20 17:39 3 -> /opt/nginx/logs/access.log
lrwx------ 1 root root 64 Oct 20 17:39 6 -> socket:[2917557592]
lrwx------ 1 root root 64 Oct 20 17:39 7 -> socket:[2917557593]
l-wx------ 1 root root 64 Oct 20 17:39 8 -> /opt/nginx/logs/error.log
lrwx------ 1 root root 64 Oct 20 17:39 9 -> socket:[2917559816]

 

limits:

该文件存储了进程的软限制,硬限制等信息。

 可以查看该进程允许打开的最大描述字个数。

 

 

maps:

 

 

      address         perms offset  dev   inode   pathname

      08048000-08056000 r-xp 00000000 03:0c 64593   /usr/sbin/gpm

      4001f000-40135000 r-xp 00000000 03:0c 45494   /lib/libc-2.2.4.so

         * address:进程占用的地址空间。

         * perms:权限集

                 r = read

                 w = write

                 x = execute

                 s = shared

                 p = private (copy on write)

        * offset:文件偏移量。

        * dev:为设备(major:minor)

        * inode:设备上的inode。0为没有inode关联互内存区域,通常为:BSS(uninitialized data)

 

root:

指向进程更目录的软链

 

smaps:

 

      This file shows memory consumption for each of the process's mappings.  For each of mappings there is a series of lines such as the following:

 

  08048000-080bc000 r-xp 00000000 03:02 13130    /bin/bash

  Size:       464 kB

  Rss:       424 kB

  Shared_Clean:       424 kB

  Shared_Dirty: 0 kB

  Private_Clean: 0 kB

  Private_Dirty: 0 kB

 

      The first of these lines shows the same information as is displayed for the mapping in /proc/[pid]/maps. The remaining lines show the size of

      the  mapping,  the amount of the mapping that is currently resident in RAM, the number of clean and dirty shared pages in the mapping, and the

      number of clean and dirty private pages in the mapping.

 

      This file is only present if the CONFIG_MMU kernel configuration option is enabled.

 
status:
  Name:   bash
  State:  S (sleeping)
  Tgid:   3515
  Pid:   3515
  PPid:   3452
  TracerPid:   0
  Uid:   1000   1000   1000   1000
  Gid:   100   100   100   100
  FDSize: 256
  Groups: 16 33 100
  VmPeak:     9136 kB
  VmSize:     7896 kB
  VmLck:  0 kB
  VmHWM:      7572 kB
  VmRSS:      6316 kB
  VmData:     5224 kB
  VmStk: 88 kB
  VmExe:       572 kB
  VmLib:      1708 kB
  VmPTE: 20 kB
  Threads:   1
  SigQ:   0/3067
  SigPnd: 0000000000000000
  ShdPnd: 0000000000000000
  SigBlk: 0000000000010000
  SigIgn: 0000000000384004
  SigCgt: 000000004b813efb
  CapInh: 0000000000000000
  CapPrm: 0000000000000000
  CapEff: 0000000000000000
  CapBnd: ffffffffffffffff
  Cpus_allowed:   00000001
  Cpus_allowed_list:   0
  Mems_allowed:   1
  Mems_allowed_list:   0
  voluntary_ctxt_switches:   150
  nonvoluntary_ctxt_switches:   545
 
      The fields are as follows:
 
      * Name: Command run by this process.
 
      * State: Current state of the process.  One of "R (running)", "S (sleeping)", "D (disk sleep)", "T (stopped)", "T (tracing  stop)",  "Z  (zom-
bie)", or "X (dead)".
 
      * Tgid: Thread group ID (i.e., Process ID).
 
      * Pid: Thread ID (see gettid(2)).
 
      * TracerPid: PID of process tracing this process (0 if not being traced).
 
      * Uid, Gid: Real, effective, saved set, and file system UIDs (GIDs).
 
      * FDSize: Number of file descriptor slots currently allocated.
 
      * Groups: Supplementary group list.
 
      * VmPeak: Peak virtual memory size.
 
      * VmSize: Virtual memory size.
 
      * VmLck: Locked memory size.
 
      * VmHWM: Peak resident set size ("high water mark").
 
      * VmRSS: Resident set size.
 
      * VmData, VmStk, VmExe: Size of data, stack, and text segments.
 
      * VmLib: Shared library code size.
 
      * VmPTE: Page table entries size (since Linux 2.6.10).
 
      * Threads: Number of threads in process containing this thread.
 
      * SigPnd, ShdPnd: Number of signals pending for thread and for process as a whole (see pthreads(7) and signal(7)).
 
      * SigBlk, SigIgn, SigCgt: Masks indicating signals being blocked, ignored, and caught (see signal(7)).
 
      * CapInh, CapPrm, CapEff: Masks of capabilities enabled in inheritable, permitted, and effective sets (see capabilities(7)).
 
      * CapBnd: Capability Bounding set (since kernel 2.6.26, see capabilities(7)).
 
      * Cpus_allowed: Mask of CPUs on which this process may run (since Linux 2.6.24, see cpuset(7)).
 
      * Cpus_allowed_list: Same as previous, but in "list format" (since Linux 2.6.26, see cpuset(7)).
 
      * Mems_allowed: Mask of memory nodes allowed to this process (since Linux 2.6.24, see cpuset(7)).
 
      * Mems_allowed_list: Same as previous, but in "list format" (since Linux 2.6.26, see cpuset(7)).
 
      * voluntary_context_switches, nonvoluntary_context_switches: Number of voluntary and involuntary context switches (since Linux 2.6.23).
 
task:
进程包含的线程,子目录名是线程的ID

一、/proc/pid/statm

pid/statm包含了在此进程中所有CPU活跃的信息,该文件中的所有值都是从系统启动开始累计到当前时刻。

 

/proc/1 # cat statm

550 70 62 451 0 97 0

 

输出解释

CPU 以及CPU0。。。的每行的每个参数意思(以第一行为例)为:

参数 解释 /proc/1/status

Size (pages)= 550  任务虚拟地址空间的大小 VmSize/4

Resident(pages)= 70  应用程序正在使用的物理内存的大小 VmRSS/4

Shared(pages)= 62  共享页数

Trs(pages)= 451  程序所拥有的可执行虚拟内存的大小 VmExe/4

Lrs(pages)= 0  被映像到任务的虚拟内存空间的库的大小 VmLib/4

Drs(pages)= 97  程序数据段和用户态的栈的大小 VmData+ VmStk 4

dt(pages) 0

 

二、/proc/pid/stat

pid/stat包含了进程所有CPU活跃的信息,该文件中的所有值都是从系统启动开始累计到当前时刻。

/proc/1 # cat stat

1 (linuxrc) S 0 0 0 0 -1 8388864 50 633 20 4 2 357 72 342 16 0 1 0 22 2252800 70 4294967295 32768 1879936 3199270704 3199269552 1113432 0 0 0 674311 3221479524 0 0 0 0 0 0

 

每个参数意思为:

参数 解释

pid=1 进程(包括轻量级进程,即线程)

comm= linuxrc 应用程序或命令的名字

task_state=S 任务的状态,R:runnign, S:sleeping (TASK_INTERRUPTIBLE), D:disk sleep (TASK_UNINTERRUPTIBLE), T: stopped, T:tracing stop,Z:zombie, X:dead

ppid=0 父进程ID

pgid=0 线程组号

sid=0 c该任务所在的会话组ID

tty_nr=0(pts/3) 该任务的tty终端的设备号,INT0/256=主设备号,(0-主设备号)=次设备号

tty_pgrp=-1 终端的进程组号,当前运行在该任务所在终端的前台任务(包括shell 应用程序)PID

task->flags=8388864进程标志位,查看该任务的特性

min_flt=50该任务不需要从硬盘拷数据而发生的缺页(次缺页)的次数

cmin_flt=633 累计的该任务的所有的waited-for进程曾经发生的次缺页的次数目

maj_flt=20该任务需要从硬盘拷数据而发生的缺页(主缺页)的次数

cmaj_flt=4 累计的该任务的所有的waited-for进程曾经发生的主缺页的次数目

utime=2 该任务在用户态运行的时间,单位为jiffies

stime=357 该任务在核心态运行的时间,单位为jiffies

cutime=72 累计的该任务的所有的waited-for进程曾经在用户态运行的时间,单位为jiffies

cstime=342 累计的该任务的所有的waited-for进程曾经在核心态运行的时间,单位为jiffies

priority=16 任务的动态优先级

nice=0 任务的静态优先级

num_threads=1 该任务所在的线程组里线程的个数

it_real_value=0 由于计时间隔导致的下一个 SIGALRM 发送进程的时延,以 jiffy 为单位.

start_time=22 该任务启动的时间,单位为jiffies

vsize=2252800bytes 该任务的虚拟地址空间大小

rss=70(page) 该任务当前驻留物理地址空间的大小

Number of pages the process has in real memory,minu 3 for administrative purpose.

这些页可能用于代码,数据和栈。

rlim=4294967295=0xFFFFFFFFbytes 该任务能驻留物理地址空间的最大值

start_code=32768=0x8000  该任务在虚拟地址空间的代码段的起始地址(由连接器决定)

end_code=1879936该任务在虚拟地址空间的代码段的结束地址

start_stack=3199270704=0Xbeb0ff30该任务在虚拟地址空间的栈的开始地址

kstkesp=3199269552  sp(32 位堆栈指针的当前值与在进程的内核堆栈页得到的一致.

kstkeip=1113432 =0X10FD58 指向将要执行的指令的指针, PC(32 位指令指针)的当前值.

pendingsig=0 待处理信号的位图,记录发送给进程的普通信号

block_sig=0 阻塞信号的位图

sigign=0 忽略的信号的位图

sigcatch=674311被俘获的信号的位图

wchan=3221479524  如果该进程是睡眠状态,该值给出调度的调用点

nswap=0 swapped的页数

cnswap=0 所有子进程被swapped的页数的和

exit_signal=0  该进程结束时,向父进程所发送的信号

task_cpu(task)=0 运行在哪个CPU

task_rt_priority=0 实时进程的相对优先级别

task_policy=0 进程的调度策略,0=非实时进程,1=FIFO实时进程;2=RR实时进程 

 

三、/proc/pid/status

包含了所有CPU活跃的信息,该文件中的所有值都是从系统启动开始累计到当前时刻。

 

/proc/286 # cat status

Name:   mmtest

State:  R (running)

SleepAVG:       0%

Tgid:   286

Pid:    286

PPid:   243

TracerPid:      0

Uid:    0       0       0       0

Gid:    0       0       0       0

FDSize: 32

Groups:

VmPeak:     1464 kB

VmSize:     1464 kB

VmLck:         0 kB

VmHWM:       344 kB

VmRSS:       344 kB

VmData:       20 kB

VmStk:        84 kB

VmExe:         4 kB

VmLib:      1300 kB

VmPTE:         6 kB

Threads:        1

SigQ:   0/256

SigPnd: 0000000000000000

ShdPnd: 0000000000000000

SigBlk: 0000000000000000

SigIgn: 0000000000000000

SigCgt: 0000000000000000

CapInh: 0000000000000000

CapPrm: 00000000fffffeff

CapEff: 00000000fffffeff

 

输出解释

参数 解释

Name 应用程序或命令的名字

State 任务的状态,运行/睡眠/僵死/

SleepAVG 任务的平均等待时间(nanosecond为单位),交互式任务因为休眠次数多、时间长,它们的 sleep_avg 也会相应地更大一些,所以计算出来的优先级也会相应高一些。

Tgid=286 线程组号

Pid=286 任务ID

Ppid=243 父进程ID

TracerPid=0 接收跟踪该进程信息的进程的ID

Uid Uid euid suid fsuid

Gid Gid egid sgid fsgid

FDSize=32 文件描述符的最大个数,最多能打开的文件句柄的个数file->fds

Groups

VmPeak: 60184 kB /*进程地址空间的大小*/
VmHWM: 18020 kB /*文件内存映射和匿名内存映射的大小*/

VmSize(KB)=1499136 任务虚拟地址空间的大小 (total_vm-reserved_vm),其中total_vm为进程的地址空间的大小,reserved_vm:进程在预留或特殊的内存间的物理页

VmLck(KB)=0 任务已经锁住的物理内存的大小。锁住的物理内存不能交换到硬盘 (locked_vm)

VmRSS(KB)= 344 kB 应用程序正在使用的物理内存的大小,就是用ps命令的参数rss的值 (rss)

VmData(KB)=20KB 程序数据段的大小(所占虚拟内存的大小),存放初始化了的数据; (total_vm-shared_vm-stack_vm)

VmStk(KB)=84KB 任务在用户态的栈的大小 (stack_vm)

VmExe(KB)=4KB 程序所拥有的可执行虚拟内存的大小,代码段,不包括任务使用的库 (end_code-start_code)

VmLib(KB)=1300KB 被映像到任务的虚拟内存空间的库的大小 (exec_lib)

VmPTE=6KB 该进程的所有页表的大小,单位:kb

Threads=1 共享使用该信号描述符的任务的个数,在POSIX多线程序应用程序中,线程组中的所有线程使用同一个信号描述符。

SigQ 待处理信号的个数

SigPnd 屏蔽位,存储了该线程的待处理信号

ShdPnd 屏蔽位,存储了该线程组的待处理信号

SigBlk 存放被阻塞的信号

SigIgn 存放被忽略的信号

SigCgt 存放被俘获到的信号

CapInh Inheritable,能被当前进程执行的程序的继承的能力

CapPrm Permitted,进程能够使用的能力,可以包含CapEff中没有的能力,这些能力是被进程自己临时放弃的,CapEffCapPrm的一个子集,进程放弃没有必要的能力有利于提高安全性

CapEff Effective,进程的有效能力

 

四、/proc/loadavg

该文件中的所有值都是从系统启动开始累计到当前时刻。该文件只给出了所有CPU的集合信息,不能该出每个CPU的信息。

 

/proc # cat loadavg

1.0   1.00 0.93 2/19 301

 

 

每个值的含义为:

参数 解释

lavg_1 (1.0) 1-分钟平均负载

lavg_5 (1.00) 5-分钟平均负载

lavg_15(0.93) 15-分钟平均负载

nr_running (2) 在采样时刻,运行队列的任务的数目,与/proc/statprocs_running表示相同意思

nr_threads (19) 在采样时刻,系统中活跃的任务的个数(不包括运行已经结束的任务)

last_pid(301) 最大的pid值,包括轻量级进程,即线程。

假设当前有两个CPU,则每个CPU的当前任务数为4.61/2=2.31

 

五、/proc/286/smaps

该文件反映了该进程的相应线性区域的大小

/proc/286 # cat smaps

00008000-00009000 r-xp 00000000 00:0c 1695459    /memtest/mmtest

Size:                 4 kB

Rss:                  4 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        4 kB

Private_Dirty:        0 kB

00010000-00011000 rw-p 00000000 00:0c 1695459    /memtest/mmtest

Size:                 4 kB

Rss:                  4 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        4 kB

00011000-00012000 rwxp 00011000 00:00 0          [heap]

Size:                 4 kB

Rss:                  0 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        0 kB

40000000-40019000 r-xp 00000000 00:0c 2413396    /lib/ld-2.3.2.so

Size:               100 kB

Rss:                 96 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:       96 kB

Private_Dirty:        0 kB

40019000-4001b000 rw-p 40019000 00:00 0

Size:                 8 kB

Rss:                  8 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        8 kB

40021000-40022000 rw-p 00019000 00:0c 2413396    /lib/ld-2.3.2.so

Size:                 4 kB

Rss:                  4 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        4 kB

40022000-4014e000 r-xp 00000000 00:0c 2413367    /lib/libc-2.3.2.so

Size:              1200 kB

Rss:                200 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:      200 kB

Private_Dirty:        0 kB

4014e000-40152000 ---p 0012c000 00:0c 2413367    /lib/libc-2.3.2.so

Size:                16 kB

Rss:                  0 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        0 kB

40152000-4015a000 rw-p 00128000 00:0c 2413367    /lib/libc-2.3.2.so

Size:                32 kB

Rss:                 16 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:       16 kB

4015a000-4015c000 rw-p 4015a000 00:00 0

Size:                 8 kB

Rss:                  8 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        8 kB

be8f1000-be906000 rwxp be8f1000 00:00 0          [stack]

Size:                84 kB

Rss:                  4 kB

Shared_Clean:         0 kB

Shared_Dirty:         0 kB

Private_Clean:        0 kB

Private_Dirty:        4 kB

 

解释说明:

每行数据格式如下:

(内存区域)开始-结束 访问权限  偏移 主设备号:次设备号 i节点  文件。

be8f1000-be906000 rwxp be8f1000 00:00 0          [stack]

Size:相应虚拟地址空间的大小

RSS: 正在使用的物理内存的大小

Shared_Clean:  共享区域的未使用页数

Shared_Dirty:   共享区域已经使用的页数

Private_Clean:   私有区域未使用的页数

Private_Dirty:  私有区域已经使用的页数

 

六、/proc/pid/maps

该文件反映了进程占用的内存区域

/proc/286 # cat maps

00008000-00009000 r-xp 00000000 00:0c 1695459    /memtest/mmtest

00010000-00011000 rw-p 00000000 00:0c 1695459    /memtest/mmtest

00011000-00012000 rwxp 00011000 00:00 0          [heap]

40000000-40019000 r-xp 00000000 00:0c 2413396    /lib/ld-2.3.2.so

40019000-4001b000 rw-p 40019000 00:00 0

40021000-40022000 rw-p 00019000 00:0c 2413396    /lib/ld-2.3.2.so

40022000-4014e000 r-xp 00000000 00:0c 2413367    /lib/libc-2.3.2.so

4014e000-40152000 ---p 0012c000 00:0c 2413367    /lib/libc-2.3.2.so

40152000-4015a000 rw-p 00128000 00:0c 2413367    /lib/libc-2.3.2.so

4015a000-4015c000 rw-p 4015a000 00:00 0

be8f1000-be906000 rwxp be8f1000 00:00 0          [stack]

每行数据格式如下:

(内存区域)开始-结束 访问权限  偏移 主设备号:次设备号 i节点  文件。
【案例分析】

/proc文件系统,不是普通的文件系统,而是系统内核的映像,该目录中的文件时存放在系统内存中的,它以文件系统的形式为访问系统内核数据的操作提供接口。

查看内核版本命令:uname -

               或者:cat /proc/version

               或者:lsb_release -a,可以列出所有版本信息。

/proc文件下有根据进程号排列的信息:

查看进程详细信息到/proc/pid/status下寻找

/proc/pid/cmdline 进程启动命令
  /proc/pid/cwd 链接到进程当前工作目录
  /proc/pid/environ 进程环境变量列表
  /proc/pid/exe 链接到进程的执行命令文件
  /proc/pid/fd 包含进程相关的所有的文件描述符
  /proc/pid/maps 与进程相关的内存映射信息
  /proc/pid/mem 指代进程持有的内存,不可读
  /proc/pid/root 链接到进程的根目录
  /proc/pid/stat 进程的状态
  /proc/pid/statm 进程使用的内存的状态
  /proc/pid/status 进程状态信息,比stat/statm更具可读性
  /proc/self 链接到当前正在运行的进程

我们来具体研究一下/proc/pid/status文件:

red-hat 6.2下的线程也就是轻量级进程LWP,在/proc/pid下是没有的,它们是使用父进程的系统资源,使用父进程的文件描述符,内存,CPU等资源。

可以看出,linux下进程所有的线程:threads:26,这些事父进程所拥有的线程。

文件描述符;FD size,可以看到

此为,进程打开的文件信息。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Linux系统中,/proc目录下的文件目录包含了许多与系统运行状态相关的信息,下面是一些常见的或目录及其含义: 1. `/proc/cpuinfo`:显示CPU的信息,如CPU型号、频率、缓存大小等。 2. `/proc/meminfo`:显示系统内存的信息,如总内存大小、可用内存大小等。 3. `/proc/loadavg`:显示系统的平均负载,包括1分钟、5分钟、15分钟的负载。 4. `/proc/filesystems`:显示系统支持的文件系统类型。 5. `/proc/net/dev`:显示网络设备的统计信息,如接收和发送的数据包数量、错误数量等。 6. `/proc/mounts`:显示系统当前挂载的文件系统信息。 7. `/proc/sys/kernel`:包含了一些与内核相关的参数,如系统的主机名、时区等。 8. `/proc/sys/net`:包含了一些与网络相关的参数,如TCP/IP协议栈的参数、路由表等。 9. `/proc/sys/fs`:包含了一些与文件系统相关的参数,如文件系统缓存、文件句柄数量等。 注意:在/proc目录下的文件目录实际上并不是真正的文件目录,而是内核提供的接口。读取这些文件目录实际上是在读取内核中的数据结构,因此它们的内容可能会随着系统运行状态而动态变化。 ### 回答2: `/proc`目录Linux操作系统中的一个特殊目录,提供了即时系统信息和进程信息的虚拟文件系统。以下是`/proc`目录中一些重要文件目录含义: - `/proc/cpuinfo`: 该文件提供了有关系统CPU的详细信息,如制造商、型号、核心数量、缓存等。可以通过查看此文件来了解系统的处理能力和配置信息。 - `/proc/meminfo`: 该文件提供了有关系统内存的信息,如总内存量、可用内存、已使用的内存、缓存和交换空间等。可以通过查看此文件来监控系统的内存使用情况。 - `/proc/loadavg`: 该文件提供了系统的平均负载信息。负载表示系统中正在使用和等待CPU的进程数量。通过查看此文件,可以了解系统的负载情况,以便决定何时采取相应的措施。 - `/proc/net`: 该目录提供了有关网络协议、连接和统计信息文件。其中,`/proc/net/tcp`和`/proc/net/udp`文件分别显示了系统上的TCP和UDP连接信息,可以通过查看这些文件来监控系统的网络活动。 - `/proc/<PID>`: 在`/proc`目录下以进程ID命名的子目录包含了有关每个运行中进程的详细信息。每个子目录中的文件可用于查看进程的状态、内存使用、打开的文件文件系统信息等。例如,可以使用`/proc/1/status`文件来查看init进程的状态信息。 总之,`/proc`目录下的文件目录提供了丰富的系统和进程信息,可以为系统管理和性能监控提供重要参考。 ### 回答3: `/proc`目录Linux系统中的一个特殊目录,提供了对内核和正在运行的进程信息的访问。在该目录下,包含了一系列的文件目录,每个文件目录代表了系统中的一个进程或一些系统信息。 首先,`/proc`目录中的文件目录都是虚拟的文件系统,它们并不真实存在于磁盘上,而是在运行时由内核动态生成。 其中,`/proc/[PID]`目录下的文件目录代表了系统中各个进程的信息。`[PID]`指代进程的ID号,通过访问这些文件目录,可以了解进程的诸多详细信息,如进程的状态、命令行参数、内存映射、文件描述符等等。例如,可以通过`/proc/1/status`文件查看init进程的状态信息。 `/proc/[PID]/fd`目录下则包含了进程打开的文件描述符的符号链接,通过这些符号链接可以找到相应文件。 除了进程相关的信息之外,`/proc`目录下还包含了一些系统信息文件。例如,`/proc/meminfo`文件提供了系统内存的相关信息,`/proc/cpuinfo`文件则提供了CPU的相关信息。 需要强调的是,`/proc`目录下的文件都以文本形式存在,可以通过读取和解析这些文件来获得所需的信息。尽管目录文件的命名规则是明确的,但要注意文件的格式和内容在不同版本和配置的Linux上可能会有所不同。 总之,`/proc`目录是一个非常重要的系统目录,通过访问它下面的文件目录,我们可以了解系统内核和正在运行的进程的详细信息,有助于系统调试和性能优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值