文档章节

grub rescue 主引导修复

o
 osc_z1hvg4cu
发布于 2018/04/24 21:44
字数 2693
阅读 16
收藏 0

精选30+云产品,助力企业轻松上云!>>>

使用windows 和 ubuntu 双系统的人,很有可能碰到重装某一个系统,或者另外添加分区,导致系统重启出现 :

 

[html]  view plain  copy
 
  1. GRUB loading  
  2. error:unknow filesystem  
  3. grub rescue>  

 

一.概念

BIOS:"Basic Input Output System",中文名称就是"基本输入输出系统"。其实,它是一组固化到计算机内主板上一个ROM芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。 其主要功能是为计算机提供最底层的、最直接的硬件设置和控制。

 

MBR: “Master Boot Record” 硬盘的物理扇区,也叫主引导记录!因为BIOS 很小无法承载启动的运行程序,所以在bios检测到一个硬盘后,将硬盘的0柱面、0磁头、1扇区的内容经过简单判断后, 至内存中的指定位置,然后跳转至这个位置,开始从这个位置运行,大小为512个byte,其中主要存放引导程序和该硬盘的分区表。

 

GRUB:“GRand Unified Bootloade” 多重操作系统启动管理器,就是运行这个GRUB之后可以通过它来引导进入其它的系统,包括window以及linux

 

上面三个概念,从字面意思上应该能明白他们的流程,大体是:

PC 首先启动到BIOS ,然后检测硬盘的MBR,将MBR这块扇区的内容(也就是写在上面的GRUB)装入内存运行,再通过运行GRUB得到的结果实现新的跳转启动!

 

二.Ubuntu的grub2 修复

当PC 是先装windows后装ubuntu 或者只有一个ubuntu系统,是将ubuntu系统自带的grub2 引导程序写在了MBR上的话,那么开机的主引导程序就是grub2 ! (ubuntu 自9.10之后就全部使用的grub2)

而grub2 分为两部分,其中一部分写入MBR,其中一部分存在与ubuntu的/boot/grub 目录下。

而出现 grub rescue> 就是代表MBR部分的无法正常运作grub程序,启动grub 救援模式,因为无法找到/boot/grub部分。

grub rescue下可用命令:

set,ls,insmod,root,prefix(设置启动路径)

 

首先通过 ls 查看所有的分区,会列出:

(hd0),(hd0,msdos8),(hd0,msdos7),(hd0,msdos6),(hd0,msdos5),(hd0,msdos3),(hd0,msdos1)

 

需要找到ubuntu的安装分区,通过ls (hd0,msdos*)/boot 直到不出现:error:unknown filesystem

如果知道开始安装ubuntu 在哪个分区的话,比如sda7 那么这里就是msdos7,如果是在ubuntu 硬盘空间之前的地方进行了添加分区,那么就把ubuntu的分区序号往后移!变成msdos8

找到之后通过如下命令设置设置一次性启动参数:

 

[html]  view plain  copy
 
  1. grub rescue>set root=(hd0,msdos8)  
  2. grub rescue>set prefix=(hd0,msdos8)/boot/grub  
  3. grub rescue>insmod /boot/grub/normal.mod  


grub rescue>normal 就会出现boot/grub 中的启动界面了!

 

 

如果/boot/grub没有损坏,就能进入ubuntu 系统啦,如果grub启动ubuntu的部分损坏了,就需要手动引导了:

进入grub命令行:

 

[html]  view plain  copy
 
  1. grub> root (hd0,8) ## 指定包含vmlinuz-2.6.18-274.7.1.el5和initrd-2.6.18-274.7.1.el5.img的partition  
  2. grub> kernel /boot/vmlinuz-2.6.18-274.7.1.el5 ro root=/dev/sda8 ## root= 是指定包含/sbin/init的partition,即挂载/的partition(以Linux的角度)  
  3. grub> initrd /boot/initrd-2.6.18-274.7.1.el5.img ## 据说这项可以省略  
  4. grub> boot  

 

在正确进入了ubuntu之后,需要更新MBR的grub部分来适应新的分区情况:

终端输入:

 

 

[html]  view plain  copy
 
  1. sudo update-grub2  
  2. sudo grub-install/dev/sda  


更新到 /boot/grub/grub.cfg 中!然后再把grub 安装到主硬盘的MBR

 

有遇到过这样安装不成功的,在GRUB2手册中有另外的重装grub2 到MBR 的方法,记录一下:

 

[html]  view plain  copy
 
  1. 此方案安裝會使用 chroot 指令來存取受損系統的檔案。  
  2. 一旦執行了 chroot 指令,LiveCD 會將損壞系統的 / (根目錄)當作是目前自己所使用的。  
  3. 在 chroot 環境中執行的指令會影響受損系統的檔案系統,而不是 LiveCD 的。  
  4. 1. 開機進入 LiveCD 桌面(Ubuntu 9.10 或更新版)。注意此 LiveCD 必須要與您現在欲修復系統的版本相同 - 無論 32-bit 或是 64-bit(否則 chroot 會失敗)。  
  5. 2. 開啟終端機 - 應用程式,附屬應用程式,終端機。  
  6. 3. 確認您的標準系統分割區 - (選項是小寫的「L」)  
  7. sudo fdisk -l  
  8. 若您不確定,執行  
  9. df -Th  
  10. 找到正確的磁碟容量及 ext3 或 ext4 格式。  
  11. 4. 掛載您的標準系統分割區  
  12. 用正確的分割區替換:sda1, sdb5 等等。  
  13. sudo mount /dev/sdXX /mnt #範例:sudo mount /dev/sda1 /mnt  
  14. 5. 若您有獨立的 /boot 分割區:  
  15. sdYY 是 /boot 分割區的位置(例如 sdb3)  
  16. sudo mount /dev/sdYY /mnt/boot  
  17. 6. 掛載重要的虛擬檔案系統:  
  18. sudo mount --bind /dev /mnt/dev  
  19. sudo mount --bind /dev/pts /mnt/dev/pts  
  20. sudo mount --bind /proc /mnt/proc  
  21. sudo mount --bind /sys /mnt/sys  
  22. 7. Chroot 至您的標準系統裝置:  
  23. sudo chroot /mnt  
  24. 8. 若系統中沒有 /boot/grub/grub.cfg 或其內容不正確,使用以下指令重建  
  25. update-grub  
  26. 9. 重新安裝 GRUB 2:  
  27. 以正確裝置替換 - sda, sdb, 等等。不要指定分割區號碼。  
  28. grub-install /dev/sdX  
  29. 10. 驗證安裝(使用正確的裝置,例如 sda。不要指定分割區):  
  30. sudo grub-install --recheck /dev/sdX  
  31. 11. 退出 chroot:按下鍵盤之 CTRL-D  
  32. 12. 卸載虛擬檔案系統:  
  33.   
  34. sudo umount /mnt/dev/pts  
  35. sudo umount /mnt/dev  
  36. sudo umount /mnt/proc  
  37. sudo umount /mnt/sys  
  38. 若您有掛載獨立的 /boot 分割區:  
  39. sudo umount /mnt/boot  
  40. 13. 卸載 LiveCD 的 /usr 目錄:  
  41. sudo umount /mnt/usr  
  42. 14. 卸載最後的裝置:  
  43. sudo umount /mnt  
  44. 15. 重新開機。sudo reboot  



另外常用的就是,无法启动到grub界面,这个时候就需要另外的引导了,网上很多的方法是使用ubuntu的安装光盘,也就是livecd,

我常用的就是U盘,用老毛桃加载一个ubuntu 的iso 制作一个ubuntu启动U盘,然后bios选择U盘启动,

选择 try running ubuntu,不选 install 选项

这样就运行了我们制作在U盘上面的ubuntu系统,可以以这个为媒介来修改本机上其它的系统文件,像上面提到的 先mount 上那些分区:

sudo mount /dev/sdxx /mnt 

可先使用 sudo fdisk -l 命令查看分区情况,选择对应的

如果要修改对应内容 使用 chroot 切换 完了之后 ctrl+d退出

 

我这边是13.04 , grub版本为:

 

[html]  view plain  copy
 
  1. jscese@jscese-H61M-S2P:~$ grub-install -v  
  2. grub-install (GRUB) 2.00-13ubuntu3  


在这个情况下可以使用如下命令将正确的grub 安装到 MBR:

 

[html]  view plain  copy
 
  1. grub-install --root-directory=/mnt /dev/sda  


我这的sda 为第一块硬盘

 

症状:
开机显示:GRUB loading
error:unknow filesystem
grub rescue>

原因:

由于操作者不知道grub2分为两部分,一部分(一般情况下)写在了mbr上,另一部分写在了某个分区的/boot/grub目录(如果 /boot单独分区,则直接写在对应分区的/grub目录)里面。由于上述操作,致使grub2的mbr里面的那一部分找不到/grub目录里面的那一部 分了(或者那一部分已经删除了)。

思路:
方法1,彻底删除grub2,让这个提示不再出现:
适用于已经不想再使用ubuntu,要转回windows的人。
这个很简单,只要你有Windows启动盘(非Ghost),用它启动,至选择安装位置,不用真正安装,退出重启就可以。
或者用它启动到故障修复台,运行fixboot或者fixmbr都可以。
win7命令行下,则是执行:BootRec.exe /fixmbr
(/fixmbr修复mbr, /FixBoot修复启动扇区,/ScanOs检测已安装的win7,/RebuildBcd重建bcd。)

方法2,重新安装、修复grub2
1. 先使用ls命令,找到Ubuntu的安装在哪个分区:
在 grub rescue>下输入以下命令:

代码:

ls


会罗列所有的磁盘分区信息,比方说: 

引用:
(hd0,1),(hd0,5),(hd0,3),(hd0,2)


2. 然后依次调用如下命令: X表示各个分区号码

如果/boot没有单独分区,用以下命令:

代码:

ls (hd0,X)/boot/grub


如果/boot单独分区,则用下列命令: 

代码:
ls (hd0,X)/grub


正常情况下,会列出来几百个文件,很多文件的扩展名是.mod和.lst和.img,还有一个文件是grub.cfg。假设找到(hd0,5)时,显示了文件夹中的文件,则表示Linux安装在这个分区。


4,如果找到了正确的grub目录,则设法临时性将grub的两部分关联起来,方法如下:
以下是/boot没有单独分区的命令:

引用:

grub rescue>set root=(hd0,5)
grub rescue>set prefix=(hd0,5)/boot/grub
grub rescue>insmod /boot/grub/normal.mod

以下是/boot 单独分区的命令:(这几句有待验证) 

 

 

引用:
grub rescue>set root=(hd0,5)
grub rescue>set prefix=(hd0,5)/grub
grub rescue>insmod /grub/normal.mod


然后调用如下命令,就可以显示出丢失的grub菜单了。

grub rescue>normal
不过不要高兴,如果这时重启,问题依旧存在,我们需要进入Linux中,对grub进行修复。
启动起来,进入ubuntu之后,在终端执行:

代码:

    sudo update-grub
    sudo grub-install /dev/sda

(sda是你的硬盘号码,千万不要指定分区号码,例如sda1,sda5等都不对)
重启测试是否已经恢复了grub的启动菜单? 恭喜你恢复成功!
5,如果找不到正确的/grub目录,比如第3、4种误操作,则尝试寻找是否有linux核心文件,则依次调用如下命令: X表示各个分区号码:
grub rescue>下,输入:
如果/boot没有单独分区:

代码:

ls (hd0,X)/boot


如果/boot单独分区,则: 

代码:
ls (hd0,X)


找名字类似与vmlinuz-3.0.0-12-generic这样的文件,这是linux核心文件,如果找到,记下(hd0,X)中的X值。假设找到(hd0,5)时,显示了文件夹中的文件。

然后用live cd 或者 live usb启动,在live cd的ubuntu的终端中依次输入以下命令(sda5中的“5”必须改成上面记录下来数值)(这两句需要验证):
如果/boot没有单独分区:

代码:

sudo mount /dev/sda5 /mnt
sudo grub-install --boot-directory=/mnt/boot /dev/sda


如果/boot单独分区,则: 

代码:
sudo mount /dev/sda5 /mnt
sudo grub-install --boot-directory=/mnt /dev/sda


然后重新启动即可。

(以上这两句命令也可以解决安装ubuntu时grub安装位置不对,没有将grub安装到/dev/sda,造成启动时不出现ubuntu启动项直接进入windows的问题,不过需要自行确定sda5中的“5”改成什么数字。)

6,如果连linux核心文件都没有,那么,彻底重新安装吧

上一篇: getopts的使用
下一篇: 从TS流到PAT和PMT
o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

OSChina 周一乱弹 —— 毛巾又怎么样?!我在乎的是大姐姐温柔的怀抱!

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《雨 因你而下,于你而止》- Seto 手机党少年们想听歌,请使劲儿戳(这里) @Dan...

小小编辑
14分钟前
29
1
MySQL 常用操作

1 创建/打开/删除数据库 create database db;create database db character set utf8mb4;use db;drop database db;alter database db character set utf8mb4; 2 修复表 mysqlcheck --a......

氷泠
18分钟前
5
0
Node.js中的module.exports与export - module.exports vs exports in Node.js

问题: I've found the following contract in a Node.js module: 我在Node.js模块中找到了以下合同: module.exports = exports = nano = function database_module(cfg) {...} I wonder ......

javail
23分钟前
13
0
如何防止单击按钮时对话框关闭 - How to prevent a dialog from closing when a button is clicked

问题: I have a dialog with EditText for input. 我有一个使用EditText输入的对话框。 When I click the "yes" button on dialog, it will validate the input and then close the dialog.......

富含淀粉
54分钟前
17
0
访问者模式Visitor

一 概述 场景:通常来说,用于封装数据所用到的pojo类,其只包含get、set,对应的业务逻辑是在Service上完成的;但如果出现多个pojo类都共用一套逻辑时,则应该考虑将逻辑进行抽象,不同类型...

小明不觉小
今天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部