Linux系統啓動過程

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,如截圖最後的id:3:initdefault

3、接下來的第三步是進行系統的初始化操作

這個時候我們來分析上圖所示的系統相關配置文件/etc/init/rcS.conf

而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文件用於對用戶作出附加訪問限制,如果不存在這個文件,則沒有其他限制。


發佈了43 篇原創文章 · 獲贊 25 · 訪問量 7萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章