跳到主要內容

附錄 - LPIC參考資料 - Linux Quick Reference Guide - 6th ed. - Daniele Raffo - System boot

#System boot

 開機啟動序列(Boot sequence)
POST                           |     執行個人電腦硬體之低階檢查
(Power-On Self Test)

BIOS                       |     偵測磁碟與硬體
(Basic I/O System)   

Chain loader     
GRUB(GRand Unified Bootloader)    |

GRUB第一階段爲從主要啓動紀錄(MBR)載入且從檔案系統執行第二階段。GRUB可選擇要啟動哪一個作業系統連鎖載入器(Chain loader)便移交分區的啟動磁區至選擇運行的作業系統。
連鎖載入器亦掛載initrd, 其爲一初始化的快取磁碟(通常爲ext2檔案系統壓縮成),被當成核心啟動期間的初始(最底層)根裝置。它可讓核心盡可能辨認硬體裝置且可以掛載真正的根檔案系統。接著,作業系統便運行 /linuxrc ,其PID爲1(程序序號爲1)。(從Linux 2.6.13版本開始,系統便成載入initramfs 來取代前版,爲一個由CPIO壓縮方式的影像檔,並將其解壓縮至動態存取記憶體(RAM)內的之 tmpfs(暫存檔案系統)實作,接著核心便從影像檔內部開始執行/init)

Linux Kernel             |
核心解壓縮至記憶體。核心執行。偵測硬體裝置。從初始化記憶體磁碟(ramdisk)內,執行將永久的根檔案系統掛載在 /

init  |
init爲系統執行的第一個程序(PID 1)。系統接著嘗試執行以下順序:
/sbin/init
/etc/init
/bin/init
/bin/sh
假設這些程序沒有執行成功,則進入核心應急狀態。

Startup                      |      系統載入啟動腳本與執行層級(runlevel)腳本

Login |
如果在文字命令模式(runlevel 1或3),init 呼叫 getty 程序,用於執行詢問使用者登入帳號與密碼的 login 指令。如果爲圖形模式(runlevel 5),則 X 顯示管理器將啓動 X 伺服器。

較新的系統使用統一可延伸韌體介面(Unified Extensible Firmware Interface, 以下簡稱UEFI)來取代BIOS. UEFI不使用MBR啟動碼,它使用的是自行規範的分區表與檔案系統,並將應用程式存在其中,且EFI系統分區通常使用FAT32檔案系統格式。
POST執行之後,系統載入UEFI韌體來初始化啟動所需之硬體,接著讀取啟動管理員的資料來決定要執行哪一個UEFI應用程式。被執行的應用程式,可能會也執行其他的應用程式,如核心程式與initramfs在啟動載入器執行的情況(如執行GRUB)

#SysV startup sequence

起動序列(Startup sequence)

在啟動/sbin/init 時,會執行所有在/etc/inittab的指令,該腳本指令會選擇啟動預設的執行層級
Debian                                                Red Hat
id:2:initdefault:                                   id:5:initdefault:


...接著開始執行以下腳本(所有執行層級皆同)來配置周邊硬體,應用核心參數,設定主機名稱與提供磁碟初始化。
Debian                                                Red Hat
/etc/init.d/rcS                                      /etc/rc.d/rc.sysinit or /etc/rc.sysinit


...再來,對於執行層級N,稱之為 /etc/init.d/rcN腳本(註:跟據執行層級號而有不同參數),可用來執行置放於以下目錄內的所有服務與常駐程式。
Debian                                                Red Hat
/etc/rcN.d/                                           /etc/rc.d/rcN.d/

用於啟動的目錄包含初始腳本的符號連接至/etc/init.d/,其中依數字順序來執行。連接從K 開始被稱為停止(stop)引數,連結從S開始則稱為啟動(start)引數

最後一個腳本爲S99local -> ../init.d/rc.local; 因此,若要在啟動時執行特定的程式,一個簡單的方式便是再執行 /init.d/rc.local 之前執行它

/etc init.d/boot.local
只有在啟動時程執行,就算切換執行層級也不執行

/etc/init.d/before.local (SUSE)
只有在啟動時程執行,在啟動目錄內的腳本執行前

/etc/init.d/after.local (SUSE)
只有在啟動時程執行,在啟動目錄內的腳本執行後

在起動程序增加或刪減服務
Debian                                                 Red Hat
update-rc.d service defaults                chkconfig --add service
update-rc.d -f service remove              chkconfig --del service

當增加或減少一項啓動服務,啟動目錄將對預設的預設啟動層級藉由建立或刪除符號連結來更新:K 針對對於啟動層級 0 1 6,而S 則針對 2 3 4 5。
服務將從 xinetd 超級伺服器來執行。

init 腳本所提供的服務操作參數
以下爲強制
start             啓動服務
stop             停止服務
restart         重啟服務(先停止然後啟動)
status           顯示常駐程式PID與執行情況
force-reload 如果服務有支援重載入,則重新載入組態,否則重新啟動
以下爲任選
condrestart   僅在服務已經在執行中才重啟服務
try-restart
reload           重載入服務組態


Linux標準基地(Linux Standard Base,LSB)
Linux標準基地定義一種格式,其規定在一 init 腳本檔內 /etc/init.d/foo的預設數值:
### BEGIN INIT INFO
# Provides: foo
# Required-start: bar
# Default-start: 2 3 4 5
# Description: Service Foo init script
### END INIT INFO

預設執行層級與S/K符號連結值亦規定如以下:
#chkconfig: 2345 85 15
#description: Foo service

 



留言

這個網誌中的熱門文章

Linux 操作不求人系列 - 貳章之貳 - Shell Script 程式設計(II) - BASH 與 TCSH / CSH

     在上章,我們介紹很多bash shell指令的應用方式,並讓它們變成 script,在這章此節,我們要承襲上節,繼續討論 bash shell script 的其它程式設計概念,與讓程式可重複使用的方法,就是利用函式(function)。      首先,我們來創作一個判斷是否為閏年的函數,script的名稱就取為 check_year.sh ,請自行將其設為可執行。程式碼如圖2-6,為了解說方便,筆者利用指令 nl check_year.sh 將程式碼包含行數印出(圖2-7),其他除顏色外,都與圖2-6同。以下 export 宣告環境變數,自訂變數無需加宣告保留字。(2021.10.07更正export說明,以下自訂變數宣告請直接去除export開頭) (圖2-6) (圖2-7)        圖2-7第2-6行,與之前的範例相似,皆有防堵參數個數輸入錯誤的判斷。第7-11行為接著判斷輸入的年分,是否為真的正整數,也就是大於零的數字。其中第7行可解釋為,利用正規表示式搜尋 $2 字串值得頭至尾部的字元,皆由 0-9 組成,若有,則為真(True)會進入 if 內的陳述執行, 但我們想要的,應該是僅要字串其中一字元為非正整數,便進入if 內的警告並跳出 。故,筆者在判斷式前多加一個 ! ,代表著當字元完全是正整數時,就不要執行  if  內陳述,而直接往第12行執行,但若其中有一個字元為非正整數,則會進入 if 內印出錯誤訊息並跳出 Script 。在此例使用者輸入非正整數等字串(如:12ab、cde、1a1b),便會出現錯誤訊息"Error Value",並跳出 Script 。而第8行的判斷式,效果跟第7行相同,但只能在BASH 3.0才能支援,故筆者故意保留,讓讀者可以學到另一種表示方式。         第12-28行,為宣告一個函式 leapyr () ,在 BASH Script內若要使用含式,必須在使用之前先建立函式的功能,如函式建立在第12-28行,則若要呼叫使用(Call)函式,則必須在第29行之後才能呼叫,並且可重複呼叫。第13行為定義函式呼叫時,一定會有一個外部參數, 此外部參數非該 Script 的外部參數 ,而是由程式撰寫者給入,故在此無設定防呆判斷。第14-

Linux操作不求人- 肆章之壹 - 伺服器架設(I) - SSH(SFTP、SCP)、FTP伺服器與遠端連線

@ ssh, sftp      通常安裝好 CentOS6_x64 作業系統後,sshd, ssh daemon 的服務功能是預設開啟的,如筆者的前面篇章所述,預設的 iptables 防火牆設定,亦是開啟讓 ssh 的連線是可通過的,不僅可以連出,也可以被連入。若要確認是否有安裝 sshd 套件以及在啟動時的 runlevel 2 3 5 是否有被載入,可以使用以下指令搜尋: $   rpm  -qa  |   grep  openssh     #  ssh 與 sshd 連線服務皆由 openssh 應用軟體提供。 或使用以下 $   rpm  -qa  |   grep  ssh         #  比用關鍵字 openssh 搜尋更模糊,故符合的條件更多。      如圖4-1可以查詢到有關於 openssh-client 與 openssh-server 的套件, openssh-server 便是提供連入服務的軟體,openssh-client 為提供可以連出的工具。若無以上套件,則使用 yum install openssh ,則可下載安裝。 (圖4-1) 再接著輸入以下指令查詢到 sshd 這個服務,是否有再開機程序內載入,如圖4-2 $ chkconfig | grep ssh   # 查詢 sshd 是否有於 開機 runlevel 啟動 再利用以下指令,來查詢是否防火牆有允許連線 $ iptables  -L  |  grep ssh   # 出現如圖4-2 允許通過之條件 (圖4-2)      接下來,我們要先來調整 sshd 的設定檔,利用 vim  /etc/sshd/sshd_conf ,如圖4-3-1與4-3-2。因為設定檔參數很多,筆者為方便說明,將 /etc/sshd/sshd_conf 檔案內容分成兩張圖。 (圖4-3-1)

Linux操作不求人 - 伍章之陸 - Intel PXE 與利用 tftp + anaconda kickstart來自動部署系統

     現代的個人電腦與筆電爲了節能省碳,往往皆省略了光碟機的設置。雖然說 USB隨身碟亦可應用於安裝作業系統,但若遇到機房的大量機器需安裝之問題,亦不適合此種用光碟片或隨身碟逐臺安裝的方式,或是需準備多片光碟或隨身碟。故爲了大量安裝與部屬 Linux作業系統的機器,我們便可透過具有PXE功能之網路卡(https://en.wikipedia.org/wiki/Preboot_Execution_Environment),其所具備的網路開機的能力,來作透過網路方式來安裝與大量部署 CentOS Linux作業系統。其原理 wikipedia  的PXE說明,都解釋得很清楚,筆者不需要再 " 掉書包 ",在開發者大神面前班門弄斧,我們就直接來做做看。      首先,我們一樣透過 yum來安裝所需的 tftp伺服器軟體(http://www.jounin.net/tftpd32.html),利用PXE支援 tftp 透過 udp 埠號 69連線,來提供檔案的能力,給利用 PXE開機後安裝作業系統的機器,圖5-60   (圖5-60) 接著修改 tftp 設定檔 /etc/xinetd.d/tftp,如圖5-61,請記得 disable  要改為 no (圖5-61)      若要修改 server_args 參數為自訂的 tftp root 路徑,記得要變更 SELinux 的權限設定,如要改為/tftpboot,則使用指令 chcon  來調整,如以下: $ mkdir /tftpboot $ chcon  --reference /var/lib/tftpboot  /tftpboot 接著將 xinetd 與 tftp 加入開機啟動,並重啟動 xinetd,如下: $ chkconfig  --level  235  xinetd on $ chkconfig  --level  235  tftp  on $ service xinetd restart 開放防火牆通行 $ iptables -A INPUT -p udp --dport 69 -j ACCEPT $ service iptables re