Linux下/proc目录简介

来源:互联网 发布:c语言中竖线 编辑:程序博客网 时间:2024/06/06 19:04
  1. /proc目录
    Linux 内核提供了一种通过 /proc 文件系统,在运行时访问内核内部数据结构、改变内核设置的机制。proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。
    用户和应用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。由于系统的信息,如进程,是动态改变的,所以用户或应用程序读取proc文件时,proc文件系统是动态从系统内核读出所需信息并提交的。下面列出的这些文件或子文件夹,并不是都是在你的系统中存在,这取决于你的内核配置和装载的模块。另外,在/proc下还有三个很重要的目录:net,scsi和sys。 Sys目录是可写的,可以通过它来访问或修改内核的参数,而net和scsi则依赖于内核配置。例如,如果系统不支持scsi,则scsi 目录不存在。
    除了以上介绍的这些,还有的是一些以数字命名的目录,它们是进程目录。系统中当前运行的每一个进程都有对应的一个目录在/proc下,以进程的 PID号为目录名,它们是读取进程信息的接口。而self目录则是读取进程本身的信息接口,是一个link。

  2. 子文件或子文件夹
    /proc/buddyinfo 每个内存区中的每个order有多少块可用,和内存碎片问题有关
    /proc/cmdline 启动时传递给kernel的参数信息
    /proc/cpuinfo cpu的信息
    /proc/crypto 内核使用的所有已安装的加密密码及细节
    /proc/devices 已经加载的设备并分类

    /proc/dma 已注册使用的ISA DMA频道列表
    /proc/execdomains Linux内核当前支持的execution domains
    /proc/fb 帧缓冲设备列表,包括数量和控制它的驱动
    /proc/filesystems 内核当前支持的文件系统类型
    /proc/interrupts x86架构中的每个IRQ中断数
    /proc/iomem 每个物理设备当前在系统内存中的映射
    /proc/ioports 一个设备的输入输出所使用的注册端口范围
    /proc/kcore 代表系统的物理内存,存储为核心文件格式,里边显示的是字节数,等于RAM大小加上4kb
    /proc/kmsg 记录内核生成的信息,可以通过/sbin/klogd或/bin/dmesg来处理
    /proc/loadavg 根据过去一段时间内CPU和IO的状态得出的负载状态,与uptime命令有关
    /proc/locks 内核锁住的文件列表
    /proc/mdstat 多硬盘,RAID配置信息(md=multiple disks)
    /proc/meminfo RAM使用的相关信息
    /proc/misc 其他的主要设备(设备号为10)上注册的驱动
    /proc/modules 所有加载到内核的模块列表
    /proc/mounts 系统中使用的所有挂载
    /proc/mtrr 系统使用的Memory Type Range Registers (MTRRs)
    /proc/partitions 分区中的块分配信息
    /proc/pci 系统中的PCI设备列表
    /proc/slabinfo 系统中所有活动的 slab 缓存信息
    /proc/stat 所有的CPU活动信息
    /proc/sysrq-trigger 使用echo命令来写这个文件的时候,远程root用户可以执行大多数的系统请求关键命令,就好像在本地终端执行一样。要写入这个文件,需要把/proc/sys/kernel/sysrq不能设置为0。这个文件对root也是不可读的
    /proc/uptime 系统已经运行了多久
    /proc/swaps 交换空间的使用情况
    /proc/version Linux内核版本和gcc版本
    /proc/bus 系统总线(Bus)信息,例如pci/usb等
    /proc/driver 驱动信息
    /proc/fs 文件系统信息
    /proc/ide ide设备信息
    /proc/irq 中断请求设备信息
    /proc/net 网卡设备信息
    /proc/scsi scsi设备信息
    /proc/tty tty设备信息
    /proc/net/dev 显示网络适配器及统计信息
    /proc/vmstat 虚拟内存统计信息
    /proc/vmcore 内核panic时的内存映像
    /proc/diskstats 取得磁盘信息
    /proc/schedstat kernel调度器的统计信息
    /proc/zoneinfo 显示内存空间的统计信息,对分析虚拟内存行为很有用
    以下是/proc目录中进程N的信息
    /proc/N pid为N的进程信息
    /proc/N/cmdline 进程启动命令
    /proc/N/cwd 链接到进程当前工作目录
    /proc/N/environ 进程环境变量列表
    /proc/N/exe 链接到进程的执行命令文件
    /proc/N/fd 包含进程相关的所有的文件描述符
    /proc/N/maps 与进程相关的内存映射信息
    /proc/N/mem 指代进程持有的内存,不可读
    /proc/N/root 链接到进程的根目录
    /proc/N/stat 进程的状态
    /proc/N/statm 进程使用的内存的状态
    /proc/N/status 进程状态信息,比stat/statm更具可读性
    /proc/self 链接到当前正在运行的进程

    3.例子
    3.1 /proc/
    yafang@QA:~$ ls /proc/
    1 16819 21242 2180 2494 8768 interrupts partitions
    116 16820 21244 2181 2524 885 iomem sched_debug
    11740 17901 21245 21810 2525 acpi ioports scsi
    11742 17903 21247 21812 3 asound irq self
    11743 17904 2131 21813 39 buddyinfo kallsyms slabinfo
    13452 18362 21319 21923 4 bus kcore stat
    13454 18364 2132 2193 41 cgroups key-users swaps
    13455 18365 2139 21933 42 cmdline kmsg sys
    149 19451 2142 2209 5 cpuinfo kpagecount sysrq-trigger
    150 19453 21572 2212 5330 crypto kpageflags sysvipc
    151 19454 21574 2219 596 devices loadavg timer_list
    152 2 21575 2243 597 diskstats locks timer_stats
    15771 2083 2158 2260 6 dma meminfo tty
    15773 2092 21625 2261 617 driver misc uptime
    15774 2101 21627 2262 619 execdomains modules version
    16232 21112 21628 2263 7 fb mounts vmallocinfo
    16234 21115 2165 2264 804 filesystems mtrr vmstat
    16235 21116 2167 2265 8765 fs net zoneinfo
    16811 2112 2177 2338 8767 ide pagetypeinfo

    3.2 /proc/sys
    系统信息和内核参数
    yafang@QA:~$ ls /proc/sys
    debug dev fs kernel net vm

    3.3 /proc/net
    网卡设备信息
    yafang@QA:~$ ls /proc/net
    anycast6 ip6_flowlabel netfilter raw6 sockstat6 udplite
    arp ip6_mr_cache netlink route softnet_stat udplite6
    dev ip6_mr_vif netstat rt6_stats stat unix
    dev_mcast ip_mr_cache packet rt_acct tcp vlan
    dev_snmp6 ip_mr_vif protocols rt_cache tcp6 wireless
    if_inet6 ipv6_route psched snmp tr_rif
    igmp mcfilter ptype snmp6 udp
    igmp6 mcfilter6 raw sockstat udp6

    3.4 /proc/scsi
    SCSI设备信息
    yafang@QA:~$ ls /proc/scsi
    device_info scsi

    3.5 /proc/modules
    所有加载到内核的模块列表
    root@BDSP-A-2-1-2:~# cat /proc/modules
    bdspboard 8486 2 dspcontrol, Live 0xe134c000
    dspcontrol 9575 1 clkmon, Live 0xe135b000
    clkmon 6765 1 - Live 0xe136c000
    diagint 6635 1 - Live 0xe1379000
    bdsprio 10775 2 srioif,tsi577, Live 0xe9389000
    tsi577 17998 1 srioif, Live 0xe939e000
    srioif 7329 0 - Live 0xe93b2000
    linux_kernel_bde 54666 1 linux_user_bde, Live 0xf1417000 (P)
    linux_user_bde 17849 0 - Live 0xf1427000 (P)

    3.6 /proc/devices
    已经加载的设备并分类
    root@BCNMB-A:~# cat /proc/devices

    Character devices:
    1 mem
    2 pty
    3 ttyp
    4 /dev/vc/0
    4 tty
    4 ttyS
    5 /dev/tty
    5 /dev/console
    5 /dev/ptmx
    7 vcs
    10 misc
    13 input
    89 i2c
    90 mtd
    116 linux-user-bde2
    117 linux-kernel-bde2
    126 linux-user-bde
    127 linux-kernel-bde
    128 ptm
    136 pts
    180 usb
    189 usb_device
    245 ext_alarm
    251 ipmidev
    252 usb_endpoint
    253 usbmon
    254 rtc

    Block devices:
    1 ramdisk
    8 sd
    31 mtdblock
    65 sd
    66 sd
    67 sd
    68 sd
    69 sd
    70 sd
    71 sd
    128 sd
    129 sd
    130 sd
    131 sd
    132 sd
    133 sd
    134 sd
    135 sd

    3.7 /proc/partitions
    分区中的块分配信息
    root@BDSP-A-2-1-2:~# cat /proc/partitions
    major minor #blocks name
    31 0 512 mtdblock0
    31 1 512 mtdblock1
    31 2 123904 mtdblock2
    31 3 4096 mtdblock3
    31 4 1024 mtdblock4
    31 5 1024 mtdblock5
    31 6 512 mtdblock6
    31 7 512 mtdblock7
    31 8 123904 mtdblock8
    31 9 4096 mtdblock9
    31 10 1024 mtdblock10
    31 11 1024 mtdblock11
    31 12 1048576 mtdblock12

    3.8 /proc/version
    Linux内核版本和gcc版本
    root@BDSP-A-2-1-2:~# cat /proc/version
    Linux version 2.6.34.6-WR4.0.0.0_standard (satomi@CharlieBrown) (gcc version 4.4.1 (Wind River Linux Sourcery G++ 4.4-291) ) #1 SMP PREEMPT Fri Nov 26 16:07:47 CST 2010

    3.9 /proc/sys/fs/file-max
    该文件指定了可以分配的文件句柄的最大数目。如果用户得到的错误消息声明由于打开文件数已经达到了最大值,从而他们不能打开更多文件,则可能需要增加该值。可将这个值设置成有任意多个文件,并且能通过将一个新数字值写入该文件来更改该值。默认设置时4096。
    改变内核的参数,用vi编辑或echo参数重定向到文件中。
    cat /proc/sys/fs/file-max
    4096
    echo 8192 > /proc/sys/fs/file-max
    cat /proc/sys/fs/file-max
    8192
    如果优化了参数,则可以把它们写成添加到文件rc.local中,使它在系统启动时自动完成修改。

    linux下/proc/stat字段含义
    linuxuser
    user system nice idle iowait irq softirq
    cpu 17906755 86377 53312329 1322524322 29311124 101704 1096939
    cpu0 4665564 22883 13417357 330376020 7206071 99986 297154
    cpu1 4488897 20352 13351971 330749128 7202582 0 271926
    cpu2 4434851 22675 13302518 330622140 7455115 1718 245786
    cpu3 4317443 20467 13240483 330777034 7447356 0 282073
    第一行是总的情况
    第二行到第五行分别代表每个cpu的情况

    对这个文件需要读取两遍,我们用total表示累计总资源,那么user+sys就是我们想要知道的累计CPU占用的资源。每个变量后面的数字表示它是第几次读文件得到的,用如下方法可算出CPU占用率:
    Total_1=user_1+nice_1+sys_1+idle_1
    Total_2=user_2+nice_2+sys_2+idle_2
    Rate={[(user_2+sys_2)-(user_1+sys_1)]/(total_2-total_1)}*100

    [root@localhost ~]# cat /proc/self/status
    Name: cat
    State: R (running)
    SleepAVG: 88%
    Tgid: 5783
    Pid: 5783
    PPid: 5742
    TracerPid: 0
    Uid: 0 0 0 0
    Gid: 0 0 0 0
    FDSize: 256
    Groups: 0 1 2 3 4 6 10
    VmSize: 6588 kB
    VmLck: 0 kB
    VmRSS: 400 kB
    VmData: 144 kB
    VmStk: 2040 kB
    VmExe: 14 kB
    VmLib: 1250 kB
    StaBrk: 0804e000 kB
    Brk: 088df000 kB
    StaStk: bfe03270 kB
    ExecLim: 0804c000
    Threads: 1
    SigPnd: 0000000000000000
    ShdPnd: 0000000000000000
    SigBlk: 0000000000000000
    SigIgn: 0000000000000000
    SigCgt: 0000000000000000
    CapInh: 0000000000000000
    CapPrm: 00000000fffffeff
    CapEff: 00000000fffffeff

    输出解释
    参数 解释
    Name 应用程序或命令的名字
    State 任务的状态,运行/睡眠/僵死/
    SleepAVG 任务的平均等待时间(以nanosecond为单位),交互式任务因为休眠次数多、时间长,它们的 sleep_avg 也会相应地更大一些,所以计算出来的优先级也会相应高一些。
    Tgid 线程组号
    Pid 任务ID
    Ppid 父进程ID
    TracerPid 接收跟踪该进程信息的进程的ID号
    Uid Uid euid suid fsuid
    Gid Gid egid sgid fsgid
    FDSize 文件描述符的最大个数,file->fds
    Groups
    VmSize(KB) 任务虚拟地址空间的大小 (total_vm-reserved_vm),其中total_vm为进程的地址空间的大小,reserved_vm:进程在预留或特殊的内存间的物理页
    VmLck(KB) 任务已经锁住的物理内存的大小。锁住的物理内存不能交换到硬盘 (locked_vm)
    VmRSS(KB) 应用程序正在使用的物理内存的大小,就是用ps命令的参数rss的值 (rss)
    VmData(KB) 程序数据段的大小(所占虚拟内存的大小),存放初始化了的数据; (total_vm-shared_vm-stack_vm)
    VmStk(KB) 任务在用户态的栈的大小 (stack_vm)
    VmExe(KB) 程序所拥有的可执行虚拟内存的大小,代码段,不包括任务使用的库 (end_code-start_code)
    VmLib(KB) 被映像到任务的虚拟内存空间的库的大小 (exec_lib)
    VmPTE 该进程的所有页表的大小,单位:kb
    Threads 共享使用该信号描述符的任务的个数,在POSIX多线程序应用程序中,线程组中的所有线程使用同一个信号描述符。
    SigQ 待处理信号的个数
    SigPnd 屏蔽位,存储了该线程的待处理信号
    ShdPnd 屏蔽位,存储了该线程组的待处理信号
    SigBlk 存放被阻塞的信号
    SigIgn 存放被忽略的信号
    SigCgt 存放被俘获到的信号
    CapInh Inheritable,能被当前进程执行的程序的继承的能力
    CapPrm Permitted,进程能够使用的能力,可以包含CapEff中没有的能力,这些能力是被进程自己临时放弃的,CapEff是CapPrm的一个子集,进程放弃没有必要的能力有利于提高安全性
    CapEff Effective,进程的有效能力

转自http://blog.sina.com.cn/s/blog_5546a5ad010007mq.html

0 0