1.甚么是proc
視察LINUX F8的/etc/rc.d/sysinit文件可以發(fā)現(xiàn),在該腳本的21行出現(xiàn)以下語句:
proc文件系統(tǒng)是1個(gè)偽文件系統(tǒng),它只存在內(nèi)存當(dāng)中,而不占用外存空間。它以文件系統(tǒng)的方式為訪問系統(tǒng)內(nèi)核數(shù)據(jù)的操作提供接口。用戶和利用程序可以通過proc得到系統(tǒng)的信息,并可以改變內(nèi)核的某些參數(shù)。由于系統(tǒng)的信息,如進(jìn)程,是動(dòng)態(tài)改變的,所以用戶或利用程序讀取proc文件時(shí),proc文件系統(tǒng)是動(dòng)態(tài)從系統(tǒng)內(nèi)核讀出所需信息并提交的。
2. proc的主要目錄和文件
它的主要目錄和文件結(jié)構(gòu)以下:(/proc/)
如圖1所示,2088號(hào)進(jìn)程是由startx命令產(chǎn)生的,即當(dāng)前的Xwindows模式。
圖1
3. proc目錄下的cmdline是甚么
在/etc/rc.d/sysinit腳本的306行出現(xiàn)了以下代碼:
cmdline=$(cat /proc/cmdline)
意思是把/proc/cmdline的內(nèi)容賦予cmdline變量。而前面說過/proc/cmdline的內(nèi)容指的是內(nèi)核命令行。我們先不去糾纏甚么是內(nèi)核命令行,來看看它的內(nèi)容。如圖2所示。
圖2
可以發(fā)現(xiàn),它的內(nèi)容是1段1段離散的字段。很明顯這些字符是由內(nèi)核產(chǎn)生的,它們表示了系統(tǒng)運(yùn)行環(huán)境的1些基本信息,它們?cè)谙到y(tǒng)完全啟動(dòng)之前就已肯定。這些字段就像標(biāo)志位1樣,因爾后續(xù)的啟動(dòng),就能夠根據(jù)這些“標(biāo)志位”來進(jìn)行相干的啟動(dòng)操作。
那末它是由誰產(chǎn)生的呢?粗糙的講,可以說是由grub生成的。Grub(Grand Unified Bootloader)引導(dǎo)加載程序,它是計(jì)算機(jī)讀取完BIOS信息后,從第1個(gè)啟動(dòng)裝備的MBR中被讀取的內(nèi)容。沒有它,核心根本就不能被加載到系統(tǒng)上。Grub的功能有很多,我們暫時(shí)不需要深入的了解。其中的kernel語句,告知了磁盤的MBR到甚么地方去讀取系統(tǒng)內(nèi)核和輔助系統(tǒng)啟動(dòng)的initrd(InitalRAM Disk)印象文件在甚么地方。同時(shí)可以加入1些啟動(dòng)參數(shù),如是不是打開RHGB,是不是強(qiáng)迫掃描...而這些字段,都統(tǒng)統(tǒng)的反應(yīng)在了內(nèi)核虛擬文件系統(tǒng)/proc里面的cmdline里面。
因此,當(dāng)我們需要在系統(tǒng)啟動(dòng)的時(shí)候判斷某些服務(wù)是不是被激活時(shí),固然要看看/proc/cmdline里面的內(nèi)容啦。