1.甚么是proc
视察LINUX F8的/etc/rc.d/sysinit文件可以发现,在该脚本的21行出现以下语句:
proc文件系统是1个伪文件系统,它只存在内存当中,而不占用外存空间。它以文件系统的方式为访问系统内核数据的操作提供接口。用户和利用程序可以通过proc得到系统的信息,并可以改变内核的某些参数。由于系统的信息,如进程,是动态改变的,所以用户或利用程序读取proc文件时,proc文件系统是动态从系统内核读出所需信息并提交的。
2. proc的主要目录和文件
它的主要目录和文件结构以下:(/proc/)
如图1所示,2088号进程是由startx命令产生的,即当前的Xwindows模式。
图1
3. proc目录下的cmdline是甚么
在/etc/rc.d/sysinit脚本的306行出现了以下代码:
cmdline=$(cat /proc/cmdline)
意思是把/proc/cmdline的内容赋予cmdline变量。而前面说过/proc/cmdline的内容指的是内核命令行。我们先不去纠缠甚么是内核命令行,来看看它的内容。如图2所示。
图2
可以发现,它的内容是1段1段离散的字段。很明显这些字符是由内核产生的,它们表示了系统运行环境的1些基本信息,它们在系统完全启动之前就已肯定。这些字段就像标志位1样,因尔后续的启动,就能够根据这些“标志位”来进行相干的启动操作。
那末它是由谁产生的呢?粗糙的讲,可以说是由grub生成的。Grub(Grand Unified Bootloader)引导加载程序,它是计算机读取完BIOS信息后,从第1个启动装备的MBR中被读取的内容。没有它,核心根本就不能被加载到系统上。Grub的功能有很多,我们暂时不需要深入的了解。其中的kernel语句,告知了磁盘的MBR到甚么地方去读取系统内核和辅助系统启动的initrd(InitalRAM Disk)印象文件在甚么地方。同时可以加入1些启动参数,如是不是打开RHGB,是不是强迫扫描...而这些字段,都统统的反应在了内核虚拟文件系统/proc里面的cmdline里面。
因此,当我们需要在系统启动的时候判断某些服务是不是被激活时,固然要看看/proc/cmdline里面的内容啦。