天天看點

RHCE 學習筆記(27) grub 和開機排錯

這一節學習了grub的概念,開機調用順序,如何自定義grub檔案,以及對一些常見的系統啟動錯誤如何排錯等等。

之前學習了mbr分區的前446個位元組存放的是系統引導程式grub,中間64位元組是分區表,最後2個位元組表示結束。那麼什麼是grub是怎麼工作的呢?

簡單的說,開機會經曆以下幾步:

bios自檢,檢查硬體;

激活mbr,mbr上不存在檔案系統,可以視作硬體一部分,是以可以被直接讀取

grub加載到記憶體,生成一個微系統,微系統内置了精簡版的檔案系統

通過這個微系統,他會去引導分區,比如預設一般是sda1上去找核心檔案如vmlinuz,然後再調用grub的配置檔案。

grub的主要把他的配置檔案放在了3個地方。

/boot/grub2/grub.cfg  

/etc/grub.d/  

/etc/default/grub    

如下所示。他們的關系是 grub.cfg裡面通過 ####begin  ##### 這種格式按照順序調用/etc/grub.d裡面的腳本實作不同的功能。grub.d目錄裡面有很多數字開頭的腳本,按照從小到大的順序執行。以00__header為例,他又會調用 /etc/default/grub 配置檔案來實作最基本的開機界面配置。

RHCE 學習筆記(27) grub 和開機排錯

比如說,在/etc/grub2/grub.cfg 檔案裡面調用 /etc/grub.d/10_linux 來配置不同的核心,這裡面有2個 menuentry (菜單入口),是以我們開機的時候會看見兩個預設選項,一個是普通模式,一個是救援模式。

RHCE 學習筆記(27) grub 和開機排錯

這個是/etc/default/grub 檔案。和其他的腳本比較起來,非常簡單直覺了。後面會舉例如何修改

RHCE 學習筆記(27) grub 和開機排錯

值得注意的是,千萬不要直接去修改 /etc/grub2/grub.cfg 檔案。 這個是因為如果後期更新核心,所有的配置都會失效。如果需要自定義這個檔案,我們可以修改對應的腳本或者 /etc/default/grub檔案,然後通過 grub2-mkconfig 重新生成grub.cfg檔案。

下面來看看如何修改一些簡單的設定。

例1: 修改啟動的等待時間

預設是5秒

RHCE 學習筆記(27) grub 和開機排錯

我改成-1,那麼開機每次必須手動确認才可以了

RHCE 學習筆記(27) grub 和開機排錯

修改之後重新編譯一下

RHCE 學習筆記(27) grub 和開機排錯

開機就沒有自動等待的時間了,必須手動确認

RHCE 學習筆記(27) grub 和開機排錯

例2 修改網卡的顯示名字,這個前面做網絡配置的時候提到過,這裡不贅述了。

RHCE 學習筆記(27) grub 和開機排錯
RHCE 學習筆記(27) grub 和開機排錯

例3: 加密grub

開機界面的時候如果輸入e,會打開編輯視窗,我們可以根據需要進入rescue, emergency 或者 shell 模式。如何限制通路。

在00_header 檔案末尾,添加以下内容

RHCE 學習筆記(27) grub 和開機排錯

重新編譯

重新開機之後 輸入e,就需要使用者和密碼才能進入編輯視窗了

RHCE 學習筆記(27) grub 和開機排錯
RHCE 學習筆記(27) grub 和開機排錯

在這個編輯視窗,我們可以根據需要進入 rescue,emergency和 shell引導的3種模式。這3種模式對于系統啟動排錯很有幫助,比如某個服務卡住了無法加載我們可以通過這3種模式來排錯。

rescue模式: 在commandline的配置末尾添加 s ,類似rhel6之前的單使用者模式

RHCE 學習筆記(27) grub 和開機排錯

普通模式需要加載的服務很多,但是這個rescue模式加載的就少很多了,輸入管理者密碼就可以進入了。這個時候再來看看相關配置和日志等資訊。

RHCE 學習筆記(27) grub 和開機排錯

emergency 模式和rescue模式類似,不過加載的服務更少,把s改成 emergency就行了

RHCE 學習筆記(27) grub 和開機排錯

一樣需要輸入管理者密碼

RHCE 學習筆記(27) grub 和開機排錯

那麼如果忘記root密碼了怎麼辦?! 

在linux16 的最後一行删除 rhgb quiet, 然後添加 init=/bin/sh, 他會用shell替代預設的daemon程序

RHCE 學習筆記(27) grub 和開機排錯
RHCE 學習筆記(27) grub 和開機排錯

進來之後改改密碼吧,貌似不行。

RHCE 學習筆記(27) grub 和開機排錯

原因很簡單,根目錄加載的權限是ro,隻讀    

RHCE 學習筆記(27) grub 和開機排錯

重新加載成 rw的權限

RHCE 學習筆記(27) grub 和開機排錯

這個時候就可以修改密碼了

RHCE 學習筆記(27) grub 和開機排錯

别忘記了selinux,建立這個檔案會自動在開啟的時候重新做标簽

RHCE 學習筆記(27) grub 和開機排錯

重新開機看看

RHCE 學習筆記(27) grub 和開機排錯

開機排錯技巧:

例1. 如果grub檔案壞了怎麼辦,比如下面我把前446個位元組都寫成0覆寫了

RHCE 學習筆記(27) grub 和開機排錯

開機的時候會自動嘗試從本地,CD光牒和網絡加載引導程式;這裡是從我的CD光牒加載的,因為本地的引導程式已經沒有了

選擇troubleshooting (查錯)

RHCE 學習筆記(27) grub 和開機排錯

選擇 rescue

RHCE 學習筆記(27) grub 和開機排錯

選擇continue,注意有耐心多等一下,有的時候會卡個10秒才有反應

RHCE 學習筆記(27) grub 和開機排錯

看看提示,本機系統被挂載到/mnt/sysimge裡面,确認ok

RHCE 學習筆記(27) grub 和開機排錯

按照提示,切換根到本機的系統

RHCE 學習筆記(27) grub 和開機排錯

fdisk -l 看看啟動分區是哪個,有星号的就是

RHCE 學習筆記(27) grub 和開機排錯

重裝一下 grub2 到啟動分區就可以了

RHCE 學習筆記(27) grub 和開機排錯

重新開機okay

RHCE 學習筆記(27) grub 和開機排錯

例2:如果grub引導程式沒問題,但是我們把核心檔案或者grub.cfg配置檔案給删除了怎麼辦

看看目前有哪些檔案,全删了

RHCE 學習筆記(27) grub 和開機排錯

重新開機之後,直接進入grub的救援模式,這表明引導程式木有問題,但是引導檔案找不到了

RHCE 學習筆記(27) grub 和開機排錯

和前面一樣,CD光牒啟動

切換根目錄,挂載一下CD光牒到/iso, 順便看看/boot目錄,裡面空蕩蕩的,核心檔案和配置檔案都沒了

RHCE 學習筆記(27) grub 和開機排錯
RHCE 學習筆記(27) grub 和開機排錯

沒了的話那就從頭安裝吧,安裝核心可以用rpm 或者yum,用yum需要先解除安裝目前的,再安裝; rpm可以強行--force覆寫安裝。

用yum 安裝

RHCE 學習筆記(27) grub 和開機排錯

或者 rpm 也可以(這裡我是重複操作了2次,因為由于圖形界面的問題,我以為哪裡出問題了)

RHCE 學習筆記(27) grub 和開機排錯

裝完核心之後,重新安裝一次 grub2, 輸入 grub2-install /dev/sda, 然後重新編譯一下grub2就行了

RHCE 學習筆記(27) grub 和開機排錯

重新開機

重新開機之後,我還遇見了2個問題,第一個問題是啟動的時候顯示i/o錯誤,經度娘谷歌确認,關掉軟碟驅動即可; 

第二個問題是開機直接進入指令行模式,即使runlevel顯示的是5,手動輸入startx一樣報錯。解決方式是重新安裝圖形化界面

yum grouplist

yum groupinstall 'server with gui'