南飓风 发表于 2024-6-3 16:32:29

/proc的相关知识

/proc的相关知识

/proc 介绍

/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关系统硬件及当前正在运行进程的信息,乃至可以通过更改此中某些文件来改变内核的运行状态。
简单来讲,/proc 目次即生存在系统内存中的信息。
/proc 目次中包含很多以数字命名的子目次,这些数字表现系统当前正在运行进程的进程号(PID),里面包含对应进程相关的多个信息文件。
/proc/self 介绍

/proc/self 表现当前进程目次。前面说了通过/proc/$pid/来获取指定进程的信息。如果某个进程想要获取当前进程的系统信息,就可以通过进程的pid来访问/proc/$pid/目次。但是这个方法还必要获取进程pid.为了更方便的获取本进程的信息,linux提供了 /proc/self/ 目次,这个目次比较独特,不同的进程访问该目次时得到的信息是不同的,内容等价于 /proc/本进程pid/ 。进程可以通过访问/proc/self/ 目次来获取自己的系统信息,而不用每次都获取pid。
如何利用

cmdline

获取当前启动进程的完整命令
cat /proc/self/cmdline以上命令返回的效果,就是启动当前进程的命令
cwd

cwd 文件是一个指向当前进程运行目次的符号链接。可以通过查看cwd文件获取目标指定进程环境的运行目次
ls /proc/self/cwdexe

获取当前进程的可实行文件的完整路径
ls -al /proc/self/exeenviron

获取当前进程的环境变量信息
cat /proc/self/environmaps

/proc/self/maps 的内容是当前进程的内存映射关系,可通过读取该文件来得到内存数据映射的地址。
字段值依次为:内存区域--权限--文件在内存中的偏移量--装备号--文件索引节点--路径
路径中/usr/bin/cat 表现二进制文件
https://img2023.cnblogs.com/blog/3159215/202406/3159215-20240603132140666-460650814.png
mem

/proc/self/mem 的内容是当前进程的内存映射关系,可通过读取该文件来得到内存数据映射的地址。但是注意该文件不能直接读取,因为文件中存在着一些无法读取的未被映射区域。所以要联合/proc/self/maps中的偏移地址进行读取。通过参数start和end及偏移地址值读取内容。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: /proc的相关知识