proc文件系统是一个虚拟文件系统,它存储了当前内核运行状态相关文件,并且文件的内容都是动态创建的。用户可以通过查看这些文件获取系统状态以及当前正在运行的进程信息。而通过了解这些信息,能够帮助我们帮助我们定位疑难问题。本文将简单介绍通过proc文件系统能够获取哪些有用的信息。
我们进入到/proc目录下,查看所有文件:
cd /proc
ls -al
774 acpi iomem mtrr uptime
775 asound ioports net version
781 buddyinfo irq pagetypeinfo version_signature
782 bus kallsyms partitions vmallocinfo
8 cgroups kcore sched_debug vmstat
813 cmdline keys schedstat zoneinfo
9 consoles key-users scsi
973 cpuinfo kmsg self
974 crypto kpagecgroup slabinfo
978 devices kpagecount softirqs
98 diskstats kpageflags stat
983 dma loadavg swaps
984 driver locks sys
987 execdomains mdstat sysrq-trigger
99 fb meminfo sysvipc
994 filesystems misc thread-self
996 fs modules timer_list
998 interrupts mounts tty
(列出部分内容)
可以看到有三类内容:
事实上,很多获取系统信息的命令都是通过读取/proc下相关文件内容获取的,例如uname,df,ps等。多数情况下,它们能满足我们对系统状态的查看需求,但是并不尽然,因此我们需要简单了解/proc下的文件,帮助我们获取更多信息。毕竟它是一个巨大的信息宝库。
cat /proc/cpuinfo
列出的内容较多,这里不展示。举例说明几点,其他内容可自行查阅:
head -2 meminfo #读取前两行内容
MemTotal: 8039600 kB #可支配内存
MemFree: 2762872 kB #尚未使用内存
watch -n 1 cat /proc/net/dev #实时刷新网络流量信息
因篇幅有限,系统状态信息文件不再一一介绍,它们所包含内容大致如下:
以数字命名的文件夹中存储着进程的相关信息。而数字本身就是该进程的pid。也就是说,如果想要知道某个进程当前更多的状态信息,只需要知道该进程的pid(参考ps命令常见实用用法),然后读取/proc/pid下的文件夹或文件内容即可。
我们随意进入一个进程id的进程信息文件夹,例如:
cd /proc/7263
ls
attr exe mounts projid_map status
autogroup fd mountstats root syscall
auxv fdinfo net sched task
cgroup gid_map ns schedstat timers
clear_refs io numa_maps sessionid timerslack_ns
cmdline limits oom_adj setgroups uid_map
comm loginuid oom_score smaps wchan
coredump_filter map_files oom_score_adj smaps_rollup
cpuset maps pagemap stack
cwd mem patch_state stat
environ mountinfo personality statm
我们可以看到该进程的很多内容,包括:
/proc/pid下的内容很多,我们不一一列举。那么这些内容有什么用呢?我们举几个简单的例子。例如我们发现程序运行时打开一个文件失败,并且没有足够的信息判断失败原因,那么我们就可以考虑查看该进程打开的文件描述符是否已达到上限。这里我们可以查看/proc/pid下的limits中的文件描述符限制数量:
sed -n "/open/p" limits
Max open files 1024 1048576 files
可以看到最大可打开的文件数量的软限制为1024,而再次进入到fd目录,计算总的打开的文件数量(参考ls命令常见实用用法):
ls -lR | grep "^l" | wc -l
4
这里得到的大小为4,很显然没有超出打开的最大文件数量限制。我们甚至还可以看到到底打开了哪些文件:
ls -al
lrwx------ 1 hyb hyb 64 11月 18 11:36 0 -> /dev/pts/2
lrwx------ 1 hyb hyb 64 11月 18 11:36 1 -> /dev/pts/2
lrwx------ 1 hyb hyb 64 11月 18 11:18 2 -> /dev/pts/2
(列出部分内容)
注:文件描述符0,1,2分别代表了标准输入,标准输出和标准错误输出。
再比如,进程在当前目录创建一个文件失败,而又无更多异常信息,可以查看进程的cwd链接指向,如果指向了一个不在预期内的目录,那么可能是工作目录被意外更改掉了。
proc文件系统相关内容过于丰富,本文仅仅做简单介绍。每一项的具体内容含义,以及在实际中的应用,本文不做过多阐述,后面的文章将会继续介绍。/proc/pid下的内容对于问题的定位也十分地有帮助,本文只有简单举例,更多的使用也会在后续文章中不断应用。