1.什麼是proc
觀察LINUX F8的/etc/rc.d/sysinit文件可以發現,在該腳本的21行出現如下語句:
復制代碼代碼如下:
if [ ! -e/proc/mounts ]; then
mount -n -t proc /proc /proc
mount -n -t sysfs /sys /sys >/dev/null 2>&1
fi
這斷話的意思是,如果/proc/mounts文件存在,便掛載proc類型的文件系統的proc設備到proc目錄下,掛載sysfs類型的文件系統的sys設備到/sys目錄下。那麼,究竟proc文件系統是什麼東西呢?
proc文件系統是一個偽文件系統,它只存在內存當中,而不占用外存空間。它以文件系統的方式為訪問系統內核數據的操作提供接口。用戶和應用程序可以通過proc得到系統的信息,並可以改變內核的某些參數。由於系統的信息,如進程,是動態改變的,所以用戶或應用程序讀取proc文件時,proc文件系統是動態從系統內核讀出所需信息並提交的。
2. proc的主要目錄和文件
它的主要目錄和文件結構如下:(/proc/)
復制代碼代碼如下:
apm # 高級電源管理信息
bus # 總線配置信息(USB的配置也記錄在此)
cmdline # 內核命令行
Cpuinfo # 關於Cpu信息
Devices # 可以用到的設備(塊設備/字符設備)
Dma # 使用的DMA通道
Filesystems # 支持的文件系統
Interrupts # 中斷的使用
Ioports # I/O端口的使用
Kcore # 內核核心印象
Kmsg # 內核消息
Ksyms # 內核符號表
Loadavg # 負載均衡
Locks # 內核鎖
Meminfo # 內存信息
Misc # 雜項
Modules # 加載模塊列表(可以想成是驅動程序)
Mounts # 加載的文件系統
Partitions # 系統識別的分區表
PCI # 在PCI總線上,每台設備的詳細情況(可以使用lspci來查看)
Rtc # 實時時鐘
Slabinfo Slab # 池信息
Stat # 全面統計狀態表
Swaps # 對換空間的利用情況
Version # 內核版本
Uptime # 系統正常運行時間
除了以上的目錄外,主機上正在運行的各進程的PID號也以目錄名的形式存在於/proc目錄下。其中cmdline文件和environ文件值得一提,前者表示啟動這個進程的命令串;後者是這個進程的環境變量的內容。它們均可以使用cat命令進行查看。
如圖1所示,2088號進程是由startx命令產生的,即當前的Xwindows模式。
圖1
3. proc目錄下的cmdline是什麼
在/etc/rc.d/sysinit腳本的306行出現了如下代碼:
復制代碼代碼如下:
cmdline=$(cat /proc/cmdline)
意思是把/proc/cmdline的內容賦予cmdline變量。而前面說過/proc/cmdline的內容指的是內核命令行。我們先不去糾纏什麼是內核命令行,來看看它的內容。如圖2所示。
圖2
可以發現,它的內容是一段一段離散的字段。很顯然這些字符是由內核產生的,它們表示了系統運行環境的一些基本信息,它們在系統完全啟動之前就已經確定。這些字段就像標志位一樣,因此後續的啟動,就可以根據這些“標志位”來進行相關的啟動操作。
那麼它是由誰產生的呢?粗糙的講,可以說是由grub生成的。Grub(Grand Unified Bootloader)引導加載程序,它是計算機讀取完BIOS信息後,從第一個啟動設備的MBR中被讀取的內容。沒有它,核心根本就不能被加載到系統上。Grub的功能有很多,我們暫時不需要深入的了解。其中的kernel語句,告訴了磁盤的MBR到什麼地方去讀取系統內核以及輔助系統啟動的initrd(InitalRAM Disk)印象文件在什麼地方。同時可以加入一些啟動參數,如是否打開RHGB,是否強制掃描...而這些字段,都通通的反映在了內核虛擬文件系統/proc裡面的cmdline裡面。
因此,當我們需要在系統啟動的時候判斷某些服務是否被激活時,當然要看看/proc/cmdline裡面的內容啦。