Linux系統啓動的過程大概可以分爲5步:
1、首先加載Linux系統的內核文件
也就是boot首先讀取/boot目錄下的內核文件;
2、第二步是,運行Linux下的init進程
這個進程是所有進程的起點,這個進程程序就是/etc/inittab這個文件;
Linux系統有7個運行級別(runlevel):
- 運行級別0:系統停機狀態,系統默認運行級別不能設爲0,否則不能正常啓動
- 運行級別1:單用戶工作狀態,root權限,用於系統維護,禁止遠程登陸
- 運行級別2:多用戶狀態(沒有NFS)
- 運行級別3:完全的多用戶狀態(有NFS),登陸後進入控制檯命令行模式
- 運行級別4:系統未使用,保留
- 運行級別5:X11控制檯,登陸後進入圖形GUI模式
- 運行級別6:系統正常關閉並重啓,默認運行級別不能設爲6,否則不能正常啓動
3、接下來的第三步是進行系統的初始化操作
而rc.sysinit是一個bash shell的腳本,它主要是完成一些系統初始化的工作,rc.sysinit是每一個運行級別都要首先運行的重要腳本。
它主要完成的工作有:激活交換分區,檢查磁盤,加載硬件模塊以及其它一些需要優先執行任務。
接下來我們再看一下/etc/init/rc.conf,這個文件主要執行系統的自啓動的腳本
例如 /etc/rc.d/rc 5
這一行表示以5爲參數運行/etc/rc.d/rc,/etc/rc.d/rc是一個Shell腳本,它接受5作爲參數,去執行/etc/rc.d/rc5.d/目錄下的所有的rc啓動腳本,/etc/rc.d/rc5.d/目錄中的這些啓動腳本實際上都是一些連接文件,而不是真正的rc啓動腳本,真正的rc啓動腳本實際上都是放在/etc/rc.d/init.d/目錄下。
而這些rc啓動腳本有着類似的用法,它們一般能接受start、stop、restart、status等參數。
/etc/rc.d/rc5.d/中的rc啓動腳本通常是K或S開頭的連接文件,對於以以S開頭的啓動腳本,將以start參數來運行。
而如果發現存在相應的腳本也存在K打頭的連接,而且已經處於運行態了(以/var/lock/subsys/下的文件作爲標誌),則將首先以stop爲參數停止這些已經啓動了的守護進程,然後再重新運行。
這樣做是爲了保證是當init改變運行級別時,所有相關的守護進程都將重啓。
至於在每個運行級中將運行哪些守護進程,用戶可以通過chkconfig或setup中的"System Services"來自行設定。
第四步,進行終端的建立
rc執行完畢後,返回init。這時基本系統環境已經設置好了,各種守護進程也已經啓動了。
這是就需要建立用戶終端,便於用戶登陸了,這就需要看一下上述的第一幅圖中的/etc/init/tty.conf文件了
例如:
1:2345:respawn:/sbin/mingetty tty1
它會顯示一個文本登錄界面,這個界面就是我們經常看到的登錄界面,在這個登錄界面中會提示用戶輸入用戶名,而用戶輸入的用戶將作爲參數傳給login程序來驗證用戶的身份。
最後一步,用戶登錄
一般來說,用戶的登錄方式有三種:
- (1)命令行登錄
- (2)ssh登錄
- (3)圖形界面登錄
對於運行級別爲5的圖形方式用戶來說,他們的登錄是通過一個圖形化的登錄界面。登錄成功後可以直接進入KDE、Gnome等窗口管理器。
而本文主要講的還是文本方式登錄的情況:當我們看到mingetty的登錄界面時,我們就可以輸入用戶名和密碼來登錄系統了。
Linux的賬號驗證程序是login,login會接收mingetty傳來的用戶名作爲用戶名參數。
然後login會對用戶名進行分析:如果用戶名不是root,且存在/etc/nologin文件,login將輸出nologin文件的內容,然後退出。
這通常用來系統維護時防止非root用戶登錄。只有/etc/securetty中登記了的終端才允許root用戶登錄,如果不存在這個文件,則root可以在任何終端上登錄。
/etc/usertty文件用於對用戶作出附加訪問限制,如果不存在這個文件,則沒有其他限制。