RHCE - grub 和開機排錯

RHCE - grub 和開機排錯

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

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

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

1.  BIOS自檢,檢查硬件;

2.  激活MBR,MBR上不存在文件系統,可以視作硬件一部分,因此可以被直接讀取

3.  grub加載到內存,生成一個微系統,微系統內置了精簡版的文件系統

4.  通過這個微系統,他會去引導分區,比如默認一般是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 配置文件來實現最基本的開機界面配置。

 

 

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

 

 

 

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

 

 

 

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

 

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

 

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

 

默認是5

 

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

 

修改之後重新編譯一下

 

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

 

 

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

 

 

例3: 加密grub

 

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

 

在00_header 文件末尾,添加以下內容

 

 

重新編譯

 

重啓之後 輸入e,就需要用戶和密碼才能進入編輯窗口了

 

 

 

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

 

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

 

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

 

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

 

 

一樣需要輸入管理員密碼

 

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

 

在linux16 的最後一行刪除 rhgb quiet, 然後添加 init=/bin/sh, 他會用shell替代默認的daemon進程

 

 

 

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

 

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

重新加載成 rw的權限

 

 

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

 

別忘記了selinux,創建這個文件會自動在開啓的時候重新做標籤

 

重啓看看

 

 

開機排錯技巧:

 

例1. 如果grub文件壞了怎麼辦,比如下面我把前446個字節都寫成0覆蓋了

 

 

開機的時候會自動嘗試從本地,光盤和網絡加載引導程序;這裏是從我的光盤加載的,因爲本地的引導程序已經沒有了

 

選擇troubleshooting (查錯)

 

選擇 rescue

 

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

 

看看提示,本機系統被掛載到/mnt/sysimge裏面,確認OK

 

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

 

fdisk -l 看看啓動分區是哪個,有星號的就是

 

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

 

重啓Okay

 

 

例2:如果grub引導程序沒問題,但是我們把內核文件或者grub.cfg配置文件給刪除了怎麼辦

 

看看目前有哪些文件,全刪了

 

重啓之後,直接進入grub的救援模式,這表明引導程序木有問題,但是引導文件找不到了

 

和前面一樣,光盤啓動

 

切換根目錄,掛載一下光盤到/iso, 順便看看/boot目錄,裏面空蕩蕩的,內核文件和配置文件都沒了 mount –oloop –t iso9660 /dev/cdrom /mnt/cdrom(yum配置地址)

Yum clean all && yum list

 

沒了的話那就從頭安裝吧,安裝內核可以用rpm 或者yum,用yum需要先卸載當前的,再安裝; rpm可以強行--force覆蓋安裝。

Yum removekernel-*       先卸載內核

Yum installkernel-*     安裝內核

 

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

 

裝完內核之後,重新安裝一次 grub2, 輸入 grub2-install /dev/sda, 然後重新編譯一下grub2就行了  grub2-mkconfig –o/boot/grub2/grub.cfg

然後 同步  sync

 

重啓

 

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

 

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

 

yum grouplist

yum groupinstall'Server with GUI'

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章