dev linux proc - CSDN
  • Linux中目录proc/net/dev详解

    万次阅读 2017-09-05 10:32:59
    幸运的是Linux提供了LKM机制可以使我们在内核空间工作,在LKM机制中一个重要的组成部分就是proc伪文件系统,它为用户提供了动态操作Linux内核信息的接口,是除系统调用之外另一个重要的Linux内核空间与用户空间交换...

    在Linux系统中,系统调用是操作系统提供给应用程序使用操作系统服务的重要接口,但同时也正是通过系统调用机制,操作系统屏蔽了用户直接访问系统内核的可能性。幸运的是Linux提供了LKM机制可以使我们在内核空间工作,在LKM机制中一个重要的组成部分就是proc伪文件系统,它为用户提供了动态操作Linux内核信息的接口,是除系统调用之外另一个重要的Linux内核空间与用户空间交换数据的途径。

    而proc/net/dev就是提供给用户读取或更改网络适配器及统计信息的途径。

    根据http://www.onlamp.com/pub/a/linux/2000/11/16/LinuxAdmin.html,proc/net/dev中每一项的含义是:

    • bytes: The total number of bytes of data transmitted or received by the interface.(接口发送或接收的数据的总字节数)
    • packets: The total number of packets of data transmitted or received by the interface.(接口发送或接收的数据包总数)
    • errs: The total number of transmit or receive errors detected by the device driver.(由设备驱动程序检测到的发送或接收错误的总数)
    • drop: The total number of packets dropped by the device driver.(设备驱动程序丢弃的数据包总数)
    • fifo: The number of FIFO buffer errors.(FIFO缓冲区错误的数量)
    • frame: The number of packet framing errors.(分组帧错误的数量)
    • colls: The number of collisions detected on the interface.(接口上检测到的冲突数)
    • compressed: The number of compressed packets transmitted or received by the device driver. (This appears to be unused in the 2.2.15 kernel.)(设备驱动程序发送或接收的压缩数据包数)
    • carrier: The number of carrier losses detected by the device driver.(由设备驱动程序检测到的载波损耗的数量)
    • multicast: The number of multicast frames transmitted or received by the device driver.(设备驱动程序发送或接收的多播帧数)

    展开全文
  • linux proc目录详解

    千次阅读 2019-03-19 08:58:29
    linux proc目录详解 Linux系统上的/proc目录是一种文件系统,即proc文件系统。与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以...

    linux proc目录详解

    Linux系统上的/proc目录是一种文件系统,即proc文件系统。与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关系统硬件及当前正在运行进程的信息,甚至可以通过更改其中某些文件来改变内核的运行状态。 

    基于/proc文件系统如上所述的特殊性,其内的文件也常被称作虚拟文件,并具有一些独特的特点。例如,其中有些文件虽然使用查看命令查看时会返回大量信息,但文件本身的大小却会显示为0字节。此外,这些特殊文件中大多数文件的时间及日期属性通常为当前系统时间和日期,这跟它们随时会被刷新(存储于RAM中)有关。 

    为了查看及使用上的方便,这些文件通常会按照相关性进行分类存储于不同的目录甚至子目录中,如/proc/scsi目录中存储的就是当前系统上所有SCSI设备的相关信息,/proc/N中存储的则是系统当前正在运行的进程的相关信息,其中N为正在运行的进程(可以想象得到,在某进程结束后其相关目录则会消失)。 

    大多数虚拟文件可以使用文件查看命令如cat、more或者less进行查看,有些文件信息表述的内容可以一目了然,但也有文件的信息却不怎么具有可读性。不过,这些可读性较差的文件在使用一些命令如apm、free、lspci或top查看时却可以有着不错的表现。 

    一、进程目录中的常见文件介绍 

    /proc目录中包含许多以数字命名的子目录,这些数字表示系统当前正在运行进程的进程号,里面包含对应进程相关的多个信息文件。 

    [root@rhel5 ~]# ll /proc 
    total 0 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 1 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 10 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 11 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 1156 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 139 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 140 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:08 141 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:09 1417 
    dr-xr-xr-x  5 root      root              0 Feb  8 17:09 1418 

    上面列出的是/proc目录中一些进程相关的目录,每个目录中是当程本身相关信息的文件。下面是作者系统(RHEL5.3)上运行的一个PID为2674的进程saslauthd的相关文件,其中有些文件是每个进程都会具有的,后文会对这些常见文件做出说明。 

    [root@rhel5 ~]# ll /proc/2674 
    total 0 
    dr-xr-xr-x 2 root root 0 Feb  8 17:15 attr 
    -r-------- 1 root root 0 Feb  8 17:14 auxv 
    -r--r--r-- 1 root root 0 Feb  8 17:09 cmdline 
    -rw-r--r-- 1 root root 0 Feb  8 17:14 coredump_filter 
    -r--r--r-- 1 root root 0 Feb  8 17:14 cpuset 
    lrwxrwxrwx 1 root root 0 Feb  8 17:14 cwd -> /var/run/saslauthd 
    -r-------- 1 root root 0 Feb  8 17:14 environ 
    lrwxrwxrwx 1 root root 0 Feb  8 17:09 exe -> /usr/sbin/saslauthd 
    dr-x------ 2 root root 0 Feb  8 17:15 fd 
    -r-------- 1 root root 0 Feb  8 17:14 limits 
    -rw-r--r-- 1 root root 0 Feb  8 17:14 loginuid 
    -r--r--r-- 1 root root 0 Feb  8 17:14 maps 
    -rw------- 1 root root 0 Feb  8 17:14 mem 
    -r--r--r-- 1 root root 0 Feb  8 17:14 mounts 
    -r-------- 1 root root 0 Feb  8 17:14 mountstats 
    -rw-r--r-- 1 root root 0 Feb  8 17:14 oom_adj 
    -r--r--r-- 1 root root 0 Feb  8 17:14 oom_score 
    lrwxrwxrwx 1 root root 0 Feb  8 17:14 root -> / 
    -r--r--r-- 1 root root 0 Feb  8 17:14 schedstat 
    -r-------- 1 root root 0 Feb  8 17:14 smaps 
    -r--r--r-- 1 root root 0 Feb  8 17:09 stat 
    -r--r--r-- 1 root root 0 Feb  8 17:14 statm 
    -r--r--r-- 1 root root 0 Feb  8 17:10 status 
    dr-xr-xr-x 3 root root 0 Feb  8 17:15 task 
    -r--r--r-- 1 root root 0 Feb  8 17:14 wchan 

    1.1、cmdline — 启动当前进程的完整命令,但僵尸进程目录中的此文件不包含任何信息; 

    [root@rhel5 ~]# more /proc/2674/cmdline 
    /usr/sbin/saslauthd 

    1.2、cwd — 指向当前进程运行目录的一个符号链接; 

    1.3、environ — 当前进程的环境变量列表,彼此间用空字符(NULL)隔开;变量用大写字母表示,其值用小写字母表示; 

    [root@rhel5 ~]# more /proc/2674/environ 
    TERM=linuxauthd 

    1.4、exe — 指向启动当前进程的可执行文件(完整路径)的符号链接,通过/proc/N/exe可以启动当前进程的一个拷贝; 

    1.5、fd — 这是个目录,包含当前进程打开的每一个文件的文件描述符(file descriptor),这些文件描述符是指向实际文件的一个符号链接; 

    [root@rhel5 ~]# ll /proc/2674/fd 
    total 0 
    lrwx------ 1 root root 64 Feb  8 17:17 0 -> /dev/null 
    lrwx------ 1 root root 64 Feb  8 17:17 1 -> /dev/null 
    lrwx------ 1 root root 64 Feb  8 17:17 2 -> /dev/null 
    lrwx------ 1 root root 64 Feb  8 17:17 3 -> socket:[7990] 
    lrwx------ 1 root root 64 Feb  8 17:17 4 -> /var/run/saslauthd/saslauthd.pid 
    lrwx------ 1 root root 64 Feb  8 17:17 5 -> socket:[7991] 
    lrwx------ 1 root root 64 Feb  8 17:17 6 -> /var/run/saslauthd/mux.accept 

    1.6、limits — 当前进程所使用的每一个受限资源的软限制、硬限制和管理单元;此文件仅可由实际启动当前进程的UID用户读取;(2.6.24以后的内核版本支持此功能); 

    1.7、maps — 当前进程关联到的每个可执行文件和库文件在内存中的映射区域及其访问权限所组成的列表; 

    [root@rhel5 ~]# cat /proc/2674/maps 
    00110000-00239000 r-xp 00000000 08:02 130647     /lib/libcrypto.so.0.9.8e 
    00239000-0024c000 rwxp 00129000 08:02 130647     /lib/libcrypto.so.0.9.8e 
    0024c000-00250000 rwxp 0024c000 00:00 0 
    00250000-00252000 r-xp 00000000 08:02 130462     /lib/libdl-2.5.so 
    00252000-00253000 r-xp 00001000 08:02 130462     /lib/libdl-2.5.so 

    1.8、mem — 当前进程所占用的内存空间,由open、read和lseek等系统调用使用,不能被用户读取; 

    1.9、root — 指向当前进程运行根目录的符号链接;在Unix和Linux系统上,通常采用chroot命令使每个进程运行于独立的根目录; 

    1.10、stat — 当前进程的状态信息,包含一系统格式化后的数据列,可读性差,通常由ps命令使用; 

    1.11、statm — 当前进程占用内存的状态信息,通常以“页面”(page)表示; 

    1.12、status — 与stat所提供信息类似,但可读性较好,如下所示,每行表示一个属性信息;其详细介绍请参见 proc的man手册页; 

    [root@rhel5 ~]# more /proc/2674/status 
    Name:   saslauthd 
    State:  S (sleeping) 
    SleepAVG:       0% 
    Tgid:   2674 
    Pid:    2674 
    PPid:   1 
    TracerPid:      0 
    Uid:    0       0       0       0 
    Gid:    0       0       0       0 
    FDSize: 32 
    Groups: 
    VmPeak:     5576 kB 
    VmSize:     5572 kB 
    VmLck:         0 kB 
    VmHWM:       696 kB 
    VmRSS:       696 kB 
    ………… 

    1.13、task — 目录文件,包含由当前进程所运行的每一个线程的相关信息,每个线程的相关信息文件均保存在一个由线程号(tid)命名的目录中,这类似于其内容类似于每个进程目录中的内容;(内核2.6版本以后支持此功能) 

    二、/proc目录下常见的文件介绍 

    2.1、/proc/apm 
    高级电源管理(APM)版本信息及电池相关状态信息,通常由apm命令使用; 

    2.2、/proc/buddyinfo 
    用于诊断内存碎片问题的相关信息文件; 

    2.3、/proc/cmdline 
    在启动时传递至内核的相关参数信息,这些信息通常由lilo或grub等启动管理工具进行传递; 

    [root@rhel5 ~]# more /proc/cmdline 
    ro root=/dev/VolGroup00/LogVol00 rhgb quiet 

    2.4、/proc/cpuinfo 
    处理器的相关信息的文件; 

    2.5、/proc/crypto 
    系统上已安装的内核使用的密码算法及每个算法的详细信息列表; 

    [root@rhel5 ~]# more /proc/crypto 
    name         : crc32c 
    driver       : crc32c-generic 
    module       : kernel 
    priority     : 0 
    type         : digest 
    blocksize    : 32 
    digestsize   : 4 
    …………

    2.6、/proc/devices 
    系统已经加载的所有块设备和字符设备的信息,包含主设备号和设备组(与主设备号对应的设备类型)名; 

    [root@rhel5 ~]# more /proc/devices 
    Character devices: 
      1 mem 
      4 /dev/vc/0 
      4 tty 
      4 ttyS 
      ………… 

    Block devices: 
      1 ramdisk 
      2 fd 
      8 sd 
      …………

    2.7、/proc/diskstats 
    每块磁盘设备的磁盘I/O统计信息列表;(内核2.5.69以后的版本支持此功能) 

    2.8、/proc/dma 
    每个正在使用且注册的ISA DMA通道的信息列表; 

    [root@rhel5 ~]# more /proc/dma 
    2: floppy 
    4: cascade 

    2.9、/proc/execdomains 
    内核当前支持的执行域(每种操作系统独特“个性”)信息列表; 

    [root@rhel5 ~]# more /proc/execdomains 
    0-0     Linux                   [kernel] 

    2.10、/proc/fb 
    帧缓冲设备列表文件,包含帧缓冲设备的设备号和相关驱动信息; 

    2.11、/proc/filesystems 
    当前被内核支持的文件系统类型列表文件,被标示为nodev的文件系统表示不需要块设备的支持;通常mount一个设备时,如果没有指定文件系统类型将通过此文件来决定其所需文件系统的类型; 

    [root@rhel5 ~]# more /proc/filesystems 
    nodev   sysfs 
    nodev   rootfs 
    nodev   proc 
            iso9660 
            ext3 
    ………… 
    ………… 

    2.12、/proc/interrupts 
    X86或X86_64体系架构系统上每个IRQ相关的中断号列表;多路处理器平台上每个CPU对于每个I/O设备均有自己的中断号; 

    [root@rhel5 ~]# more /proc/interrupts 
               CPU0       
      0:    1305421    IO-APIC-edge  timer 
      1:         61    IO-APIC-edge  i8042 
    185:       1068   IO-APIC-level  eth0 
    ………… 

    2.13、/proc/iomem 
    每个物理设备上的记忆体(RAM或者ROM)在系统内存中的映射信息; 

    [root@rhel5 ~]# more /proc/iomem 
    00000000-0009f7ff : System RAM 
    0009f800-0009ffff : reserved 
    000a0000-000bffff : Video RAM area 
    000c0000-000c7fff : Video ROM 
      ………… 

    3.2.12. /proc/iomem

    http://www.centos.org/docs/5/html/5.1/Deployment_Guide/s2-proc-iomem.html

    This file shows you the current map of the system's memory for each physical device:

    00000000-0009fbff : System RAM
    0009fc00-0009ffff : reserved 
    000a0000-000bffff : Video RAM area
    000c0000-000c7fff : Video ROM 
    000f0000-000fffff : System ROM
    00100000-07ffffff : System RAM   
    00100000-00291ba8 : Kernel code
    00291ba9-002e09cb : Kernel data 
    e0000000-e3ffffff : VIA Technologies, Inc. VT82C597 [Apollo VP3] e4000000-e7ffffff : PCI Bus #01   
    e4000000-e4003fff : Matrox Graphics, Inc. MGA G200 AGP   
    e5000000-e57fffff : Matrox Graphics, Inc. MGA G200 AGP 
    e8000000-e8ffffff : PCI Bus #01   
    e8000000-e8ffffff : Matrox Graphics, Inc. MGA G200 AGP 
    ea000000-ea00007f : Digital Equipment Corporation DECchip 21140 [FasterNet]
    ea000000-ea00007f : tulip ffff0000-ffffffff : reserved

    The first column displays the memory registers used by each of the different types of memory. The second column lists the kind of memory located within those registers and displays which memory registers are used by the kernel within the system RAM or, if the network interface card has multiple Ethernet ports, the memory registers assigned for each port.

    /opt/qtmarvell/mvqt # cat /proc/iomem 
    00000000-0fffffff : System RAM 
      0002b000-00554fff : Kernel text 
      00556000-005a22f3 : Kernel data 
    10000000-1fffffff : System RAM 
    e0000000-e7ffffff : PEX0 Memory 
      e0000000-e0003fff : 0000:00:01.0 
      e0004000-e0004fff : 0000:00:01.0 
    e8000000-efffffff : PEX1 Memory 
    f1012100-f10121ff : serial8250.0 
      f1012100-f101211f : serial 
    f1090000-f10903ff : mvsdio 
      f1090000-f10903ff : mvsdio 
    f10a0000-f10a3fff : mv88fx_snd.0 
      f10a0000-f10a3fff : mv88fx_snd 
    f10c0000-f10d0000 : dovefb.0  寄存器地址映射到这个 
      f10c0000-f10d0000 : dovefb_ovly.0

    /opt/qtmarvell/mvqt # ./framebuffer 
    The framebuffer device was opened successfully.

    Fixed screen info: 
            id:          GFX Layer 0 
            smem_start:  0x12000000 
            smem_len:    33554432 
            type:        0 
            type_aux:    0 
            visual:      2 
            xpanstep:    1 
            ypanstep:    1 
            ywrapstep:   0 
            line_length: 2560 
            mmio_start:  0xf10c0000 
            mmio_len:    65537

    2.14、/proc/ioports 
    当前正在使用且已经注册过的与物理设备进行通讯的输入-输出端口范围信息列表;如下面所示,第一列表示注册的I/O端口范围,其后表示相关的设备; 

    [root@rhel5 ~]# less /proc/ioports 
    0000-001f : dma1 
    0020-0021 : pic1 
    0040-0043 : timer0 
    0050-0053 : timer1 
    0060-006f : keyboard 
    ………… 

    2.15、/proc/kallsyms 
    模块管理工具用来动态链接或绑定可装载模块的符号定义,由内核输出;(内核2.5.71以后的版本支持此功能);通常这个文件中的信息量相当大; 

    [root@rhel5 ~]# more /proc/kallsyms 
    c04011f0 T _stext 
    c04011f0 t run_init_process 
    c04011f0 T stext 
      ………… 

    2.16、/proc/kcore 
    系统使用的物理内存,以ELF核心文件(core file)格式存储,其文件大小为已使用的物理内存(RAM)加上4KB;这个文件用来检查内核数据结构的当前状态,因此,通常由GBD通常调试工具使用,但不能使用文件查看命令打开此文件; 

    2.17、/proc/kmsg 
    此文件用来保存由内核输出的信息,通常由/sbin/klogd或/bin/dmsg等程序使用,不要试图使用查看命令打开此文件; 

    2.18、/proc/loadavg 
    保存关于CPU和磁盘I/O的负载平均值,其前三列分别表示每1秒钟、每5秒钟及每15秒的负载平均值,类似于uptime命令输出的相关信息;第四列是由斜线隔开的两个数值,前者表示当前正由内核调度的实体(进程和线程)的数目,后者表示系统当前存活的内核调度实体的数目;第五列表示此文件被查看前最近一个由内核创建的进程的PID; 

    [root@rhel5 ~]# more /proc/loadavg 
    0.45 0.12 0.04 4/125 5549 

    [root@rhel5 ~]# uptime 
    06:00:54 up  1:06,  3 users,  load average: 0.45, 0.12, 0.04 

    2.19、/proc/locks 
    保存当前由内核锁定的文件的相关信息,包含内核内部的调试数据;每个锁定占据一行,且具有一个惟一的编号;如下输出信息中每行的第二列表示当前锁定使用的锁定类别,POSIX表示目前较新类型的文件锁,由lockf系统调用产生,FLOCK是传统的UNIX文件锁,由flock系统调用产生;第三列也通常由两种类型,ADVISORY表示不允许其他用户锁定此文件,但允许读取,MANDATORY表示此文件锁定期间不允许其他用户任何形式的访问; 

    [root@rhel5 ~]# more /proc/locks 
    1: POSIX  ADVISORY  WRITE 4904 fd:00:4325393 0 EOF 
    2: POSIX  ADVISORY  WRITE 4550 fd:00:2066539 0 EOF 
    3: FLOCK  ADVISORY  WRITE 4497 fd:00:2066533 0 EOF 

    2.20、/proc/mdstat 
    保存RAID相关的多块磁盘的当前状态信息,在没有使用RAID机器上,其显示为如下状态: 

    [root@rhel5 ~]# less /proc/mdstat 
    Personalities : 
    unused devices: <none> 

    2.21、/proc/meminfo 
    系统中关于当前内存的利用状况等的信息,常由free命令使用;可以使用文件查看命令直接读取此文件,其内容显示为两列,前者为统计属性,后者为对应的值; 

    [root@rhel5 ~]# less /proc/meminfo 
    MemTotal:       515492 kB 
    MemFree:          8452 kB 
    Buffers:         19724 kB 
    Cached:         376400 kB 
    SwapCached:          4 kB 
    …………

    2.22、/proc/mounts 
    在内核2.4.29版本以前,此文件的内容为系统当前挂载的所有文件系统,在2.4.19以后的内核中引进了每个进程使用独立挂载名称空间的方式,此文件则随之变成了指向/proc/self/mounts(每个进程自身挂载名称空间中的所有挂载点列表)文件的符号链接;/proc/self是一个独特的目录,后文中会对此目录进行介绍; 

    [root@rhel5 ~]# ll /proc |grep mounts 
    lrwxrwxrwx  1 root      root             11 Feb  8 06:43 mounts -> self/mounts 

    如下所示,其中第一列表示挂载的设备,第二列表示在当前目录树中的挂载点,第三点表示当前文件系统的类型,第四列表示挂载属性(ro或者rw),第五列和第六列用来匹配/etc/mtab文件中的转储(dump)属性; 


    [root@rhel5 ~]# more /proc/mounts 
    rootfs / rootfs rw 0 0 
    /dev/root / ext3 rw,data=ordered 0 0 
    /dev /dev tmpfs rw 0 0 
    /proc /proc proc rw 0 0 
    /sys /sys sysfs rw 0 0 
    /proc/bus/usb /proc/bus/usb usbfs rw 0 0 
    …………

    2.23、/proc/modules 
    当前装入内核的所有模块名称列表,可以由lsmod命令使用,也可以直接查看;如下所示,其中第一列表示模块名,第二列表示此模块占用内存空间大小,第三列表示此模块有多少实例被装入,第四列表示此模块依赖于其它哪些模块,第五列表示此模块的装载状态(Live:已经装入;Loading:正在装入;Unloading:正在卸载),第六列表示此模块在内核内存(kernel memory)中的偏移量; 

    [root@rhel5 ~]# more /proc/modules 
    autofs4 24517 2 - Live 0xe09f7000 
    hidp 23105 2 - Live 0xe0a06000 
    rfcomm 42457 0 - Live 0xe0ab3000 
    l2cap 29505 10 hidp,rfcomm, Live 0xe0aaa000 
    …………

    2.24、/proc/partitions 
    块设备每个分区的主设备号(major)和次设备号(minor)等信息,同时包括每个分区所包含的块(block)数目(如下面输出中第三列所示); 

    [root@rhel5 ~]# more /proc/partitions 
    major minor  #blocks  name 

       8     0   20971520 sda 
       8     1     104391 sda1 
       8     2    6907950 sda2 
       8     3    5630782 sda3 
       8     4          1 sda4 
       8     5    3582463 sda5 

    2.25、/proc/pci 
    内核初始化时发现的所有PCI设备及其配置信息列表,其配置信息多为某PCI设备相关IRQ信息,可读性不高,可以用“/sbin/lspci –vb”命令获得较易理解的相关信息;在2.6内核以后,此文件已为/proc/bus/pci目录及其下的文件代替; 

    2.26、/proc/slabinfo 
    在内核中频繁使用的对象(如inode、dentry等)都有自己的cache,即slab pool,而/proc/slabinfo文件列出了这些对象相关slap的信息;详情可以参见内核文档中slapinfo的手册页; 

    [root@rhel5 ~]# more /proc/slabinfo 
    slabinfo - version: 2.1 
    # name            <active_objs> <num_objs> <objsize> <objperslab> <pagesperslab> : tunables <limit> <batchcount> <sharedfactor> : slabdata <ac 
    tive_slabs> <num_slabs> <sharedavail> 
    rpc_buffers            8      8   2048    2    1 : tunables   24   12    8 : slabdata      4      4      0 
    rpc_tasks              8     20    192   20    1 : tunables  120   60    8 : slabdata      1      1      0 
    rpc_inode_cache        6      9    448    9    1 : tunables   54   27    8 : slabdata      1      1      0 
    ………… 
    ………… 
    …………

    2.27、/proc/stat 
    实时追踪自系统上次启动以来的多种统计信息;如下所示,其中, 
    “cpu”行后的八个值分别表示以1/100(jiffies)秒为单位的统计值(包括系统运行于用户模式、低优先级用户模式,运系统模式、空闲模式、I/O等待模式的时间等); 
    “intr”行给出中断的信息,第一个为自系统启动以来,发生的所有的中断的次数;然后每个数对应一个特定的中断自系统启动以来所发生的次数; 
    “ctxt”给出了自系统启动以来CPU发生的上下文交换的次数。 
    “btime”给出了从系统启动到现在为止的时间,单位为秒; 
    “processes (total_forks) 自系统启动以来所创建的任务的个数目; 
    “procs_running”:当前运行队列的任务的数目; 
    “procs_blocked”:当前被阻塞的任务的数目; 

    [root@rhel5 ~]# more /proc/stat 
    cpu  2751 26 5771 266413 2555 99 411 0 
    cpu0 2751 26 5771 266413 2555 99 411 0 
    intr 2810179 2780489 67 0 3 3 0 5 0 1 0 0 0 1707 0 0 9620 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
    0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
    0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 5504 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 12781 0 0 0 
    0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
    ctxt 427300 
    btime 1234084100 
    processes 3491 
    procs_running 1 
    procs_blocked 0 

    2.28、/proc/swaps 
    当前系统上的交换分区及其空间利用信息,如果有多个交换分区的话,则会每个交换分区的信息分别存储于/proc/swap目录中的单独文件中,而其优先级数字越低,被使用到的可能性越大;下面是作者系统中只有一个交换分区时的输出信息; 

    [root@rhel5 ~]# more /proc/swaps 
    Filename                                Type            Size    Used    Priority 
    /dev/sda8                               partition       642560  0       -1 

    2.29、/proc/uptime 
    系统上次启动以来的运行时间,如下所示,其第一个数字表示系统运行时间,第二个数字表示系统空闲时间,单位是秒; 

    [root@rhel5 ~]# more /proc/uptime 
    3809.86 3714.13 

    2.30、/proc/version 
    当前系统运行的内核版本号,在作者的RHEL5.3上还会显示系统安装的gcc版本,如下所示; 

    [root@rhel5 ~]# more /proc/version 
    Linux version 2.6.18-128.el5 (mockbuild@hs20-bc1-5.build.redhat.com) (gcc version 4.1.2 20080704 (Red Hat 4.1.2-44)) #1 SMP Wed Dec 17 11:42:39 EST 2008 

    2.31、/proc/vmstat 
    当前系统虚拟内存的多种统计数据,信息量可能会比较大,这因系统而有所不同,可读性较好;下面为作者机器上输出信息的一个片段;(2.6以后的内核支持此文件) 

    [root@rhel5 ~]# more /proc/vmstat 
    nr_anon_pages 22270 
    nr_mapped 8542 
    nr_file_pages 47706 
    nr_slab 4720 
    nr_page_table_pages 897 
    nr_dirty 21 
    nr_writeback 0 
    ………… 

    2.32、/proc/zoneinfo 
    内存区域(zone)的详细信息列表,信息量较大,下面列出的是一个输出片段: 

    [root@rhel5 ~]# more /proc/zoneinfo 
    Node 0, zone      DMA 
      pages free     1208 
            min      28 
            low      35 
            high     42 
            active   439 
            inactive 1139 
            scanned  0 (a: 7 i: 30) 
            spanned  4096 
            present  4096 
        nr_anon_pages 192 
        nr_mapped    141 
        nr_file_pages 1385 
        nr_slab      253 
        nr_page_table_pages 2 
        nr_dirty     523 
        nr_writeback 0 
        nr_unstable  0 
        nr_bounce    0 
            protection: (0, 0, 296, 296) 
      pagesets 
      all_unreclaimable: 0 
      prev_priority:     12 
      start_pfn:         0 
    …………

    三、/proc/sys目录详解 

    与 /proc下其它文件的“只读”属性不同的是,管理员可对/proc/sys子目录中的许多文件内容进行修改以更改内核的运行特性,事先可以使用“ls -l”命令查看某文件是否“可写入”。写入操作通常使用类似于“echo  DATA > /path/to/your/filename”的格式进行。需要注意的是,即使文件可写,其一般也不可以使用编辑器进行编辑。 

    3.1、/proc/sys/debug 子目录 
    此目录通常是一空目录; 

    3.2、/proc/sys/dev 子目录 
    为系统上特殊设备提供参数信息文件的目录,其不同设备的信息文件分别存储于不同的子目录中,如大多数系统上都会具有的/proc/sys/dev /cdrom和/proc/sys/dev/raid(如果内核编译时开启了支持raid的功能) 目录,其内存储的通常是系统上cdrom和raid的相关参数信息文件。

    转自:https://www.cnblogs.com/lidabo/p/5628020.html

    展开全文
  • /dev和/proc介绍

    千次阅读 2009-10-28 18:58:00
    什么是proc文件系统? proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。用户和应用程序可以通过proc得到系统的信息,并可以改变内核的...

    什么是proc文件系统?

     

    proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。用户和应用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。由于系统的信息,如进程,是动态改变的,所以用户或应用程序读取proc文件时,proc文件系统是动态从系统内核读出所需信息并提交的。它的目录结构如下:

     

    目录名称 目录内容

    apm 高级电源管理信息

    cmdline 内核命令行

    Cpuinfo 关于Cpu信息

    Devices 可以用到的设备(块设备/字符设备)

    Dma 使用的DMA通道

    Filesystems 支持的文件系统

    Interrupts 中断的使用

    Ioports I/O端口的使用

    Kcore 内核核心印象

    Kmsg 内核消息

    Ksyms 内核符号表

    Loadavg 负载均衡

    Locks 内核锁

    Meminfo 内存信息

    Misc 杂项

    Modules 加载模块列表

    Mounts 加载的文件系统

    Partitions 系统识别的分区表

    Rtc 实时时钟

    Slabinfo Slab池信息

    Stat 全面统计状态表

    Swaps 对换空间的利用情况

    Version 内核版本

    Uptime 系统正常运行时间

     

    并不是所有这些目录在你的系统中都有,这取决于你的内核配置和装载的模块。另外,在/proc下还有三个很重要的目录:net,scsi和sys。 Sys目录是可写的,可以通过它来访问或修改内核的参数(见下一部分),而net和scsi则依赖于内核配置。例如,如果系统不支持scsi,则scsi 目录不存在。

     

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

     

    目录名称 目录内容

    Cmdline 命令行参数

    Environ 环境变量值

    Fd 一个包含所有文件描述符的目录

    Mem 进程的内存被利用情况

    Stat 进程状态

    Status 进程当前状态,以可读的方式显示出来

    Cwd 当前工作目录的链接

    Exe 指向该进程的执行命令文件

    Maps 内存映象

    Statm 进程内存状态信息

    Root 链接此进程的root目录

     

    用户如果要查看系统信息,可以用cat命令。

    要改变内核的参数,只要用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 /dev目录

     

     dev 是设备(device)的英文缩写。这个目录对所有的用户都十分重要。因为在这个目录中包含了所有Linux系统中使用的外部设备。但是这里并不是放的外部设备的驱动程序。这一点和我们常用的windows, dos操作系统不一样。它实际上是一个访问这些外部设备的端口。我们可以非常方便地去访问这些外部设备,和访问一个文件,一个目录没有任何区别。

      例如:我们在系统中键入:cd /dev/cdrom 我们就可以看到光驱中的文件了。同样道理,我们键入:cd /dev/mouse 就可以看看鼠标的相关文件。在这个目录下,有一个null设备,这个东西本身没有任何意义。如果你向这个目录写入文件或内容,他们统统有去无回。

     

    /dev/null是一个非常有用的字符设备文件,送入这个设备的所有东西都被忽略,如果将任何程序的输出结果重定向到/dev/null,则看不到任何输出信息。甚至于,您可以将某一用户的shell指向/dev/null 以禁止其登陆

     

    /dev/urandom用来生成低质量的随机数序列,不信用cat /dev/urandom try 一下,

     

     

    (2)设备文件
    UNIX系统与边在本系统上的各种设备之间的通讯,通过特别文件来实现,
    就程序而言,磁盘是文件,MODEM是文件,甚至内存也是文件.所有连接到系统上
    的设备都在/dev目录中有一个文件与其对应.当在这些文件上执行I/O操作时,
    由UNIX系统将I/O操作转换成实际设备的动作.例如,文件/dev/mem是系统的内
    存,如果cat这个文件,实际上是在终端显示系统的内存.为了安全起见,这个文
    件对普通用户是不可读的.因为在任一给定时间,内存区可能含有用户登录口令或运行程序的口令,某部分文件的编辑缓冲区,缓冲区可能含有用ed
    -x命令 解密后的文本,以及用户不愿让其他人存取的种种信息. 在/dev中的文件通常称为设备文件,用ls /dev命令可以看看系统中的一
    些设备: acuo 呼叫自动拨号器 console 系统控制台 dsknn 块方式操作磁盘分区 kmem 核心内存 mem 内存 lp 打印机
    mto 块方式操作磁带 rdsknn 流方式操作的磁盘分区 rmto 流方式操作的磁带 swap 交换区 syscon 系统终端 ttynn
    终端口 x25 网络端口 等等

     

    Linux沿袭Unix的风格,将所有设备认成是一个文件。
    设备文件分为两种:
    块设备文件(b)
    字符设备文件(c)

    设备文件一般存放在/dev目录下
    /dev/hd[a-t]:IDE设备
    /dev/sd[a-z]:SCSI设备
    /dev/fd[0-7]:标准软驱
    /dev/md[0-31]:软raid设备
    /dev/loop[0-7]:本地回环设备
    /dev/ram[0-15]:内存
    /dev/null:无限数据接收设备 ,相当于回收站
    /dev/zero:无限零资源
    /dev/tty[0-63]:虚拟终端
    /dev/ttyS[0-3]:串口
    /dev/lp[0-3]:并口
    /dev/console:控制台
    /dev/fb[0-31]:framebuffer
    /dev/cdrom => /dev/hdc
    /dev/modem => /dev/ttyS[0-9]
    /dev/pilot => /dev/ttyS[0-9]

    /dev/console:控制台和/dev/tty[0-63]:虚拟终端的区别与联系
    控制抬就好比电视机上的按钮,终端好比遥控板,他们的目的都是控制电视机,但是控制台必须在本地,而终端可以在远端,系统只有一个控制台,叫console,其他的都是终端

     

     

    /dev目录下的节点是怎么创建的

    devf或者udev会自动帮你创建得。

    kobject是sysfs文件系统的基础,udev通过监测、检测sysfs来获取新创建的设备的,搜索一下版面,以前有udev的机制论述。

    展开全文
  • Linux Proc文件系统详解

    千次阅读 2017-12-24 22:06:33
    Linux Proc文件系统详解 Proc文件系统是一个伪文件系统,做为一个特殊接口来访问内核,常常挂载在/proc下,里面的大多数文件时只读的,但是我们仍然可以设置其中一些变量来改变内核设置。 通过Man5 proc  来...
    

    Linux Proc文件系统详解

    Proc文件系统是一个伪文件系统,做为一个特殊接口来访问内核,常常挂载在/proc下,里面的大多数文件时只读的,但是我们仍然可以设置其中一些变量来改变内核设置。

    通过Man5 proc  来进行查阅proc文件系统的详细信息。

    我们可以用cat more greplinux命令来进行查看proc文件系统的内容

    I)进程相关

    系统任何时刻正在运行的用户进程在/proc下都有自己的一个目录,目录的名称就是进程号的十进制表示。如/proc/1

    /proc/self是链接到正在访问proc目录的那个进程的符号链接。

    每个进程进程号目录下有以下的文件:

    cmdline文件:进程的命令行,包括程序的名称和所有的参数,僵死进程或者被交换出去的进程可能没有任何内容。如cat ./self/cmdline

    cwd目录:进程当前工作目录的符号链接

    exe文件:指向当前进程运行的二进制可执行程序的符号链接,可以直接运行它

    environ文件:记录了进程的环境信息,单个的环境字符串之间由空字节分隔,以文件结束标志作为环境结束的标志

     

    fd目录:为每个打开得文件描述符提供一个入口,它是到实际文件的索引节点的符号链接。每个索引节点包含节点所在的设备信息、加锁信息、文件的模式和类型、到该文件的链接、文件所有者和所有组ID、文件字节数等。

    maps文件:

    address                perms                            offset   dev         inode      pathname

    10000000-1064b000  r-xp          00000000 01:00         13         /ramdisk/kdvmt.linux (deleted)

    1065b000-106c6000  rwxp         0064b000 01:00         13         /ramdisk/kdvmt.linux (deleted)

    106c6000-1108d000  rwxp                  106c6000 00:00                   0

    30000000-30120000  rw-p          30000000 00:00         0

    30120000-30121000  rw-s 22000000 1f:09          8          /usr/dev/hpi2

    30121000-30122000  rw-s 21000000 1f:09          7          /usr/dev/hpi1

    30122000-30123000  rw-s 20000000 1f:09          6          /usr/dev/hpi0

    30123000-30c83000  rw-p          30123000 00:00         0

     

                       r = read

                       w = write

                       x = execute

                       s = shared

                       p = private (copy on write)

    offset是文件的偏移量, dev 是设备号(主设备号:从设备号), inode 则是设备的节点号. 0 表明没有节点与内存相对应, 就象 bss 的情形.

    root文件:root目录的符号链接,可以由chroot系统调用改变

    stat文件:包含了通常由PS显示的有关某个进程的大多数信息。

    pid %d

    进程标识.

    comm %s

    可执行文件的文件名, 包括路径. 该文件是否可见取决于该文件是否已被交换出内存.

    state %c

    ";RSDZT"; 中的一个, R 是正在运行, S 是在可中断的就绪态中睡眠, D 是在不可中断的等待或交换态中睡眠, Z 是僵死, T 是被跟踪或被停止(由于收到信号).

    ppid %d

    父进程 PID.

    pgrp %d

    进程的进程组 ID.

    session %d

    进程的会话 ID.

    tty %d

    进程所使用终端.

    tpgid %d

    当前拥有该进程所连接终端的进程所在的进程组 ID.

    flags %u

    进程标志,依赖内核版本

    minflt %u

    进程所导致的小错误(minor faults)数目, 这样的小错误(minorfaults)不需要从磁盘重新载入一个内存页.

    cminflt %u

    进程及其子进程所导致的小错误(minor faults)数目.

    majflt %u

    进程所导致的大错误(major faults)数目, 这样的大错误(majorfaults)需要重新载入内存页.

    cmajflt %u

    进程及其子进程所导致的大错误(major faults)数目.

    utime %d

    用户时间——进程被调度进用户态的时间( jiffy 为单位).

    stime %d

    系统时间——进程被调度进内核态的时间, jiffy 为单位.

    cutime %d

    累计用户时间——进程及其子进程被调度进用户态的时间, jiffy 为单位.

    cstime %d

    累计系统时间——进程及其子进程被调度进内核态的时间, jiffy 为单位.

    priority %d

    标准优先数只再加上 15, 在内核里该值总是正的.

    nice %ld

    nice

    itrealvalue%u

    下一个SIGALARM信号到来的延时, jiffy 为单位.

    starttime %d

    进程自系统启动以来的时间, jiffy 为单位.

    vsize %u

    虚拟内存大小.

    rss %u

    Resident Set Size(驻留大小): 进程所占用的真实内存大小, 以页为单位, 为便于管理而减去了 3. rss 只包括代码段, 数据

    以及堆栈的空间, 但不包括尚未要求装入内存的或已被交换出去的.

    rlim %u

    当前进程的 rss 限制, 以字节为单位, 通常为 2,147,483,647.

    startcode %u

    代码段部分地址下限.

    endcode %u

    代码段部分地址上限.

    startstack %u

    堆栈开始地址.

    kstkesp %u

    esp(32 位堆栈指针) 的当前值, 与在进程的内核堆栈页得到的一致.

    kstkeip %u

    EIP(32 位指令指针)的当前值.

    signal %d

    待处理信号的 bitmap(通常为 0).

    blocked %d

    被阻塞信号的 bitmap( shell 通常是 0, 2)

    sigignore %d

    被忽略信号的 bitmap.

    sigcatch %d

    被俘获信号的 bitmap.

    wchan %u

    进程睡眠的内核函数名

    nswap %lu

    交换出去的页数

    cnswap %lu

    累计交换出去的页数

    exit_signal %d

    退出时发送的信号名

     processor %d

     SMP处理器中最后执行的CPU ID

    status文件:进程状态,以更好的可读格式显示出来。

    statm文件:进程对内存的使用情况。

                        size      total program size

                   resident   resident set size

                   share      shared pages

                   text       text (code)

                   lib        library

                   data       data/stack

                   dt         dirty pages (unused in Linux 2.6)

    task目录:多线程程序中,task目录里面包含每个线程号的子目录,目录下内容与进程号目录相同

    II)其他系统信息

    /proc

    cmdline文件:内核的启动命令行,通过bootloader设置,grub或者u-boot

    cpuinfo文件:提供CPU的多种信息

    devices文件:列出字符设备和快设备的主设备号,以及分配到这些设备号的设备名称

    dma文件:驱动程序保留的DMA通道和保留它们的驱动程序名称

    file systems文件:列出可以使用的文件类型

    interrupts文件:列出系统注册过的中断

    ioports文件:列出了诸如磁盘驱动器、声卡等设备的IO端口范围

    kcore文件:系统的物理内存以core文件格式保存的文件

    kmsg文件:检索printk生成的内核信息,同dmesg

    ksysm文件:列出已经登记的内核符号,给出了变量或者函数的地址

    loadavg文件:列出以几个不同的时间间隔计算的系统平均负载,前三个数字表示过去1分钟、5分钟、15分钟运行队列的平均负载,随

    后正在运行任务数/活跃任务数,最后是上次使用CPU的进程号

                                                                                 1.061.06 0.95 6/85 214

    locks文件:包含在打开的文件上的加锁信息,由/linux/fs/lock.c中的get_locks_status函数产生

    mdstat文件:md设备驱动程序控制的RAID设备信息

    meminfo文件:给出了内存状态的信息,显示出系统中空闲内存、已用物理内存和交换内存的总量,还显示出内核使用的共享内存和缓

    冲区总量,free命令就是读取这个的

    misc文件:报告内核函数misc_register函数登记的设备驱动程序

    modues文件:给出可加载内核模块的信息,lsmod由此得出

    mounts文件:挂载信息

    rtc文件:硬件实时时钟的信息

    stat文件:cput利用率、磁盘、内存页、内存对换、全部中断、接触开关以及上次自举时间(1970.1.1以来的秒数)

    version文件:说明系统正在运行的内核版本

    slabinfo文件:内核slab控制器使用情况

     

    IIInet目录

    arp文件:arp

    dev文件:来自网络设备的统计,ifconfig命令就是解析它而来

    dev_mcast:列出链路层多播组

    igmp:加入的IGMP多播组

    netlinknetlingk套接口信息

    netstat:网络流量的多种统计

    raw:原始套接口的套接口表

    route:静态路由表

    rpc:包含RPC信息的目录

    rt_cache:路由缓冲

    snmpsnmpagentip/icmp/tcp/udp协议统计,各行交替给出字段名和值

    sockstat:列出使用tcp/udp/raw/pac/syn_cookies的数量

    tcpTCP连接的套接口表

    udpUDP连接的套接口表

    unixUNIX域套接口的套接口表

    其他网卡驱动加入的相关信息

     

    IV)其他繁多的目录

    proc/scsi子目录:包含一个列出所有检测到的scsi设备的文件,并且为每个控制器驱动程序建立一个目录,这个目录下面又为每个驱动实例提供一个子目录

     

    proc/sys目录:该目录下的文件基本都是内核中的一些变量,我们可以通过改变这些变量的值来改变内核的参数。该目录内容较多,且一般不常用,例子:

                                  ./fs/file-max:内核分配的文件句柄的最大数目

                                  ./fs/file-nr:已经分配的文件句柄数、已使用的句柄数、最大数

                                  ./kernel/osrelase:内核版本号

                                  ./kernel/rtsig-nr:当前队列中实时信号的数目

              ./kernel/shmall:共享内存的最大值

                                  ./core/rmem_default:套接口读缓冲的默认值

                                  ./core/wmem_default:套接口写缓冲的默认值

                                  ./net/ipv4/ip_forward:是否允许内部转发(net目录包含繁多的各种网络参数)

    展开全文
  • 摘要:关于标题内容的几点解释:1、proc目录是一个虚拟文件系统,可以为linux用户空间和内核空间提供交互它只存在于内存中,而不占实际的flash或硬盘空间2、/proc/devices/里的设备是加载驱动程序时生成的3、/dev/下的...
  • linuxproc文件夹详解

    千次阅读 2018-05-25 10:29:52
    Linux-proc proc 文件系统 在Linux中有额外的机制可以为内核和内核模块将信息发送给进程-- /proc 文件系统。最初设计的目的是允许更方便的对进程信息进行访问(因此得名),现在它被每一个有有趣的东西报告的内核...
  • Linux proc文件系统说明

    千次阅读 2018-05-04 14:13:01
    Linux上,proc是一个伪文件系统,提供了访问内核数据的方法,一般挂载在“/proc”目录,其中的大部分内容是只读的,挂载(mount)信息可能为:proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)proc文件...
  • linux /proc/devices文件与/dev目录区别

    千次阅读 2015-05-21 00:20:48
    1、proc目录是一个虚拟文件系统,可以为linux用户空间和内核空间提供交互 它只存在于内存中,而不占实际的flash或硬盘空间 2、/proc/devices/里的设备是加载驱动程序时生成的 3、/dev/下的设备是通过创建设备节点...
  • 浅谈/proc/net/dev的由来

    千次阅读 2018-06-20 11:24:31
    直到前几天遇到一个wifi的tx和rx等数据都为0的问题不得不去探索原因,起初以为/proc/net/dev是按照文件操作的方式写进去的,结果在应用层和驱动中找了一遍没有发现相关的代码,于是到linux内核代码里一探究竟,...
  • Linux下/proc目录简介

    万次阅读 多人点赞 2012-07-15 02:22:58
    Linux 内核提供了一种通过 /proc 文件系统,在运行时访问内核内部数据结构、改变内核设置的机制。proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作...
  • 一,/proc/net/dev user_00@xxxx64:~&gt; cat /proc/net/dev Inter- | Receive | Transmit  face ...
  • proc/net/dev实时网速统计实例

    千次阅读 2018-09-14 22:44:22
    在实际应用中,往往需要显示目前系统的实时网速等信息,当然获取网速等信息的软件方法很多,但是用小几行代码,并可移植性好的方法却不多,这里介绍如何通过Linuxproc文件系统进行实时获取网卡收发速率。...
  • Linux】深入解析Linux proc文件系统

    千次阅读 2018-05-24 10:19:18
    Linux上,proc是一个伪文件系统,提供了访问内核数据的方法,一般挂载在“/proc”目录,其中的大部分内容是只读的,挂载(mount)信息可能为:proc on /proc type proc (rw,nosuid,nodev,noexec,relatime)proc文件...
  • linux proc/pid/信息说明

    千次阅读 2018-03-26 14:33:47
    版权声明:本文为EnweiTech原创文章,未经博主允许不得转载。...Proc有多个功能 ,这其中包括用户可以通过它访问内核信息或用于排错,这其中一个非常有 用的功能,也是Linux变得更加特别的功能就是以文本...
  • linux proc进程信息详解

    千次阅读 2013-07-23 17:09:55
    /proc//maps 查看进程的虚拟地址空间是如何使用的。 该文件有6列,分别为: 地址:库在进程里地址范围 权限:虚拟内存的权限,r=读,w=写,x=,s=共享,p=私有; 偏移量:库在进程里地址范围 设备:映像...
  • Linux下有两个方法获取网卡列表:分析文件/proc/net/dev 和 通过ioctl()调用。代码如下。 #define MAX_INTERFACES 100 #define FIRST_INTERFACE 0 #define PROC_NET_DEV "/proc/net/dev" /
  • linux proc maps文件分析

    万次阅读 多人点赞 2014-04-13 21:02:51
    Proc/pid/maps显示进程映射了的内存区域和访问权限。对应内核中的操作集为proc_pid_maps_op,具体的导出函数为show_map。内核中进程的一段地址空间用一个vm_area_struct结构体表示,所有地址空间存储在task->mm->...
  • linux 中/proc 详解

    万次阅读 2012-11-13 15:15:46
    Linux-proc   proc 文件系统   在Linux中有额外的机制可以为内核和内核模块将信息发送给进程-- /proc 文件系统。最初设计的目的是允许更方便的对进程信息进行访问(因此得名),现在它被每一个有有趣的...
  • LinuxProc命令详解

    千次阅读 2013-11-14 15:20:41
    Linux系统上的/proc目录是一种文件系统,即proc文件系统。与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关...
1 2 3 4 5 ... 20
收藏数 124,969
精华内容 49,987
热门标签
关键字:

dev linux proc