Linux procfs 介绍

发布时间: 更新时间: 总字数:2064 阅读时间:5m 作者: IP上海 分享 网址

在许多类 Unix 计算机系统中,procfs(processes file system) 是一种基于内存的 虚拟文件系统 ,系统启动时挂载在 /proc 目录下。用于通过内核访问进程信息。

介绍

  • proc 文件系统主要是用来调试内核
  • proc 文件系统是一种内核和内核模块用来向进程(process)发送信息的机制,因此被称为 proc
  • proc 是一种伪文件系统(也称虚拟文件系统),只存在于内存中

相关文件

  • /proc/PID/cmdline 启动该进程的命令行
  • /proc/PID/cwd 当前工作目录的符号链接
  • /proc/PID/environ 影响进程的环境变量的名字和值
  • /proc/PID/exe 最初的可执行文件的符号链接,如果它还存在的话
  • /proc/PID/fd 一个目录,包含每个打开的文件描述符的符号链接
  • /proc/PID/fdinfo 一个目录,包含每个打开的文件描述符的位置和标记
  • /proc/PID/maps 一个文本文件包含内存映射文件与块的信息
  • /proc/PID/mem 一个二进制图像(image)表示进程的虚拟内存,只能通过 ptrace 化进程访问
  • /proc/PID/root 该进程所能看到的根路径的符号链接。如果没有 chroot 监狱,那么进程的根路径是/
  • /proc/PID/status 包含了进程的基本信息,包括运行状态、内存使用。
  • /proc/PID/task 一个目录包含了硬链接到该进程启动的任何任务
  • /proc/acpi/proc/apm 电源管理系统(如果有的话)对应的目录
  • /proc/buddyinfo 信息关于伙伴内存分配器用于处理内存碎片
  • /proc/bus 包含对应于计算机上各种总线的目录,如 input/PCI/USB. 在/sys/bus 下包含更丰富的信息。
  • /proc/fb 可利用的帧缓冲的列表
  • /proc/cmdline 传递给内核的启动选项。
  • /proc/cpuinfo 包含 CPU 信息,诸如厂商(vendor),型号 (family,model,model names),速度,缓存大小,逻辑核数 ,物理核数,CPU flags,以及 BogoMips.对于多核 CPU,/proc/cpuinfo 的逻辑核数"siblings"与物理核数"cpu cores"分别表示
  • /proc/crypto 可利用的加密模块列表
  • /proc/devices 字符设备与块设备列表,按照设备 ID 排序,但给出了/dev 名字的主要部分
  • /proc/diskstats 给出了每一块逻辑磁盘设备的一些信息
  • /proc/filesystems 当前时刻内核支持的文件系统的列表
  • /proc/interrupts/proc/iomem/proc/ioports/proc/irq,设备的一些与中断、内存访问有关的信息
  • /proc/kmsg 用于跟踪读取内核消息
  • /proc/meminfo 包含内核管理内存的一些汇总信息
  • /proc/modules 是/proc 最重要的文件之一,包含了当前加载的内核模块列表
  • /proc/mounts 包含了当前安装设备及安装点的符号链接
  • /proc/net/ 一个目录包含了当前网络栈的信息,特别是/proc/net/nf_conntrack列出了存在的网络连接(对跟踪路由特别有用,因为 iptables 转发被用于重定向网络连接)
  • /proc/partitions 一个设备号、尺寸与/dev 名的列表,内核用于辨别已存在的硬盘分区
  • /proc/scsi 给出任何通过 SCSI 或 RAID 控制器挂接的设备的信息
  • /proc/self (即/proc/PID/其中进程 ID 是当前进程的) 为当前进程的符号链接
  • /proc/slabinfo Linux 内核频繁使用的对象的统计信息
  • /proc/swaps 活动交换分区的信息,如尺寸、优先级等。
  • /proc/sys,动态可配置的内核选项. 其下的目录对应与内核区域,包含了可读与可写的虚拟文件(virtual file)
  • /proc/sysvipc 包括共享内存与进程间通信 (IPC)信息
  • /proc/tty 包含当前终端信息; /proc/tty/driver 是可利用的 tty 类型列表,其中的每一个是该类型的可用设备列表。
  • /proc/uptime 内核启动后经过的秒数与 idle 模式的秒数
  • /proc/version 包含 Linux 内核版本,发布号(distribution number),编译内核的 gcc 版本,其他相关的版本
  • /proc/dma 显示当前使用的 dma 通道
  • /proc/kcore 系统物理内存映像。与物理内存大小完全一样,然而实际上没有占用这么多内存;它仅仅是在程序访问它时才被创建
  • /proc/loadavg 系统“平均负载”; 3 个没有意义的指示器指出系统当前的工作量。
  • /proc/self 存放到查看/proc 的程序的进程目录的符号连接。当 2 个进程查看/proc 时,这将会是不同的连接。这主要便于程序得到它自己的进程目录。
  • /proc/stat 系统的不同状态,例如,系统启动后页面发生错误的次数。

/proc/xxx/cmdline 命令还原

还原 /proc/xxx/cmdline 中的命令主要依赖于一个关键点:命令和参数之间实际上是用空字节 (\0) 分隔的,而不是空格。

您看到的空格被删除了的现象,通常是因为直接用 cat 或文本编辑器查看该文件时,它们将这些空字节视为字符串的结束符或不可见字符,导致输出时参数粘连在一起,看起来就像空格被删了一样。

要还原为运行时的命令(包含正确的空格或分隔),您需要将文件内容中的空字节 (\0) 替换为普通的空格。

1. 使用 tr 命令(推荐)

tr 命令可以将输入中的字符进行替换。

tr '\0' ' ' < /proc/PID/cmdline
  • \0:表示空字节(Null byte)。
  • ' ':表示一个空格。
  • /proc/PID/cmdline:替换为实际的进程 ID(PID)。

示例:

假设 /proc/1234/cmdline 文件的内容是 bash\0-c\0echo hello world\0

执行 tr '\0' ' ' < /proc/1234/cmdline 的结果会是:

bash -c echo hello world

注意,末尾通常会多一个空格,因为它替换了最后一个参数后的 \0

2. 使用 xargs 命令

xargs 默认以空字节作为分隔符读取输入,可以用来将参数列表重新组合成一行,但它可能会处理一些引号和转义字符,适用于直接执行:

xargs -0 echo < /proc/PID/cmdline
  • -0:告诉 xargs 输入是用空字节 (\0) 分隔的。
  • echo:用来将参数打印出来。

3. 使用 awksed

您也可以使用更复杂的文本处理工具,不过原理相似:

使用 awk

awk -v RS='\0' '{$1=$1}1' /proc/PID/cmdline
  • -v RS='\0':设置记录分隔符(Record Separator)为空字节。
  • '{$1=$1}1':这个技巧用于强制 awk 重新计算和打印记录,从而使用默认的输出字段分隔符(一个空格)。

参考

  1. https://zh.wikipedia.org/wiki/Procfs
本文总阅读量 次 本站总访问量 次 本站总访客数
Home Archives Categories Tags Statistics