1.什么是proc
觀察LINUX F8的/etc/rc.d/sysinit文件可以發(fā)現(xiàn),在該腳本的21行出現(xiàn)如下語句:
proc文件系統(tǒng)是一個(gè)偽文件系統(tǒng),它只存在內(nèi)存當(dāng)中,而不占用外存空間。它以文件系統(tǒng)的方式為訪問系統(tǒng)內(nèi)核數(shù)據(jù)的操作提供接口。用戶和應(yīng)用程序可以通過proc得到系統(tǒng)的信息,并可以改變內(nèi)核的某些參數(shù)。由于系統(tǒng)的信息,如進(jìn)程,是動(dòng)態(tài)改變的,所以用戶或應(yīng)用程序讀取proc文件時(shí),proc文件系統(tǒng)是動(dòng)態(tài)從系統(tǒng)內(nèi)核讀出所需信息并提交的。
2. proc的主要目錄和文件
它的主要目錄和文件結(jié)構(gòu)如下:(/proc/)
除了以上的目錄外,主機(jī)上正在運(yùn)行的各進(jìn)程的PID號(hào)也以目錄名的形式存在于/proc目錄下。其中cmdline文件和environ文件值得一提,前者表示啟動(dòng)這個(gè)進(jìn)程的命令串;后者是這個(gè)進(jìn)程的環(huán)境變量的內(nèi)容。它們均可以使用cat命令進(jìn)行查看。
如圖1所示,2088號(hào)進(jìn)程是由startx命令產(chǎn)生的,即當(dāng)前的Xwindows模式。

圖1
3. proc目錄下的cmdline是什么
在/etc/rc.d/sysinit腳本的306行出現(xiàn)了如下代碼:

圖2
可以發(fā)現(xiàn),它的內(nèi)容是一段一段離散的字段。很顯然這些字符是由內(nèi)核產(chǎn)生的,它們表示了系統(tǒng)運(yùn)行環(huán)境的一些基本信息,它們?cè)谙到y(tǒng)完全啟動(dòng)之前就已經(jīng)確定。這些字段就像標(biāo)志位一樣,因此后續(xù)的啟動(dòng),就可以根據(jù)這些“標(biāo)志位”來進(jìn)行相關(guān)的啟動(dòng)操作。
那么它是由誰產(chǎn)生的呢?粗糙的講,可以說是由grub生成的。Grub(Grand Unified Bootloader)引導(dǎo)加載程序,它是計(jì)算機(jī)讀取完BIOS信息后,從第一個(gè)啟動(dòng)設(shè)備的MBR中被讀取的內(nèi)容。沒有它,核心根本就不能被加載到系統(tǒng)上。Grub的功能有很多,我們暫時(shí)不需要深入的了解。其中的kernel語句,告訴了磁盤的MBR到什么地方去讀取系統(tǒng)內(nèi)核以及輔助系統(tǒng)啟動(dòng)的initrd(InitalRAM Disk)印象文件在什么地方。同時(shí)可以加入一些啟動(dòng)參數(shù),如是否打開RHGB,是否強(qiáng)制掃描...而這些字段,都通通的反映在了內(nèi)核虛擬文件系統(tǒng)/proc里面的cmdline里面。
因此,當(dāng)我們需要在系統(tǒng)啟動(dòng)的時(shí)候判斷某些服務(wù)是否被激活時(shí),當(dāng)然要看看/proc/cmdline里面的內(nèi)容啦。
新聞熱點(diǎn)
疑難解答
圖片精選