使用windows 和 ubuntu 双系统的人,很有可能碰到重装某一个系统,或者另外添加分区,导致系统重启出现 :
- GRUB loading
- error:unknow filesystem
- 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
找到之后通过如下命令设置设置一次性启动参数:
- grub rescue>set root=(hd0,msdos8)
- grub rescue>set prefix=(hd0,msdos8)/boot/grub
- grub rescue>insmod /boot/grub/normal.mod
grub rescue>normal 就会出现boot/grub 中的启动界面了!
如果/boot/grub没有损坏,就能进入ubuntu 系统啦,如果grub启动ubuntu的部分损坏了,就需要手动引导了:
进入grub命令行:
- grub> root (hd0,8) ## 指定包含vmlinuz-2.6.18-274.7.1.el5和initrd-2.6.18-274.7.1.el5.img的partition
- grub> kernel /boot/vmlinuz-2.6.18-274.7.1.el5 ro root=/dev/sda8 ## root= 是指定包含/sbin/init的partition,即挂载/的partition(以Linux的角度)
- grub> initrd /boot/initrd-2.6.18-274.7.1.el5.img ## 据说这项可以省略
- grub> boot
在正确进入了ubuntu之后,需要更新MBR的grub部分来适应新的分区情况:
终端输入:
- sudo update-grub2
- sudo grub-install/dev/sda
更新到 /boot/grub/grub.cfg 中!然后再把grub 安装到主硬盘的MBR
有遇到过这样安装不成功的,在GRUB2手册中有另外的重装grub2 到MBR 的方法,记录一下:
- 此方案安裝會使用 chroot 指令來存取受損系統的檔案。
- 一旦執行了 chroot 指令,LiveCD 會將損壞系統的 / (根目錄)當作是目前自己所使用的。
- 在 chroot 環境中執行的指令會影響受損系統的檔案系統,而不是 LiveCD 的。
- 1. 開機進入 LiveCD 桌面(Ubuntu 9.10 或更新版)。注意此 LiveCD 必須要與您現在欲修復系統的版本相同 - 無論 32-bit 或是 64-bit(否則 chroot 會失敗)。
- 2. 開啟終端機 - 應用程式,附屬應用程式,終端機。
- 3. 確認您的標準系統分割區 - (選項是小寫的「L」)
- sudo fdisk -l
- 若您不確定,執行
- df -Th
- 找到正確的磁碟容量及 ext3 或 ext4 格式。
- 4. 掛載您的標準系統分割區
- 用正確的分割區替換:sda1, sdb5 等等。
- sudo mount /dev/sdXX /mnt #範例:sudo mount /dev/sda1 /mnt
- 5. 若您有獨立的 /boot 分割區:
- sdYY 是 /boot 分割區的位置(例如 sdb3)
- sudo mount /dev/sdYY /mnt/boot
- 6. 掛載重要的虛擬檔案系統:
- sudo mount --bind /dev /mnt/dev
- sudo mount --bind /dev/pts /mnt/dev/pts
- sudo mount --bind /proc /mnt/proc
- sudo mount --bind /sys /mnt/sys
- 7. Chroot 至您的標準系統裝置:
- sudo chroot /mnt
- 8. 若系統中沒有 /boot/grub/grub.cfg 或其內容不正確,使用以下指令重建
- update-grub
- 9. 重新安裝 GRUB 2:
- 以正確裝置替換 - sda, sdb, 等等。不要指定分割區號碼。
- grub-install /dev/sdX
- 10. 驗證安裝(使用正確的裝置,例如 sda。不要指定分割區):
- sudo grub-install --recheck /dev/sdX
- 11. 退出 chroot:按下鍵盤之 CTRL-D
- 12. 卸載虛擬檔案系統:
- sudo umount /mnt/dev/pts
- sudo umount /mnt/dev
- sudo umount /mnt/proc
- sudo umount /mnt/sys
- 若您有掛載獨立的 /boot 分割區:
- sudo umount /mnt/boot
- 13. 卸載 LiveCD 的 /usr 目錄:
- sudo umount /mnt/usr
- 14. 卸載最後的裝置:
- sudo umount /mnt
- 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版本为:
- jscese@jscese-H61M-S2P:~$ grub-install -v
- grub-install (GRUB) 2.00-13ubuntu3
在这个情况下可以使用如下命令将正确的grub 安装到 MBR:
- 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>下输入以下命令:
代码:
会罗列所有的磁盘分区信息,比方说:
2. 然后依次调用如下命令: X表示各个分区号码
如果/boot没有单独分区,用以下命令:
代码:
如果/boot单独分区,则用下列命令:
正常情况下,会列出来几百个文件,很多文件的扩展名是.mod和.lst和.img,还有一个文件是grub.cfg。假设找到(hd0,5)时,显示了文件夹中的文件,则表示Linux安装在这个分区。
4,如果找到了正确的grub目录,则设法临时性将grub的两部分关联起来,方法如下:
以下是/boot没有单独分区的命令:
引用:
grub rescue>set prefix=(hd0,5)/boot/grub
grub rescue>insmod /boot/grub/normal.mod
以下是/boot 单独分区的命令:(这几句有待验证)
grub rescue>set prefix=(hd0,5)/grub
grub rescue>insmod /grub/normal.mod
然后调用如下命令,就可以显示出丢失的grub菜单了。
grub rescue>normal
不过不要高兴,如果这时重启,问题依旧存在,我们需要进入Linux中,对grub进行修复。
启动起来,进入ubuntu之后,在终端执行:
代码:
sudo grub-install /dev/sda
(sda是你的硬盘号码,千万不要指定分区号码,例如sda1,sda5等都不对)
重启测试是否已经恢复了grub的启动菜单? 恭喜你恢复成功!
5,如果找不到正确的/grub目录,比如第3、4种误操作,则尝试寻找是否有linux核心文件,则依次调用如下命令: X表示各个分区号码:
grub rescue>下,输入:
如果/boot没有单独分区:
代码:
如果/boot单独分区,则:
找名字类似与vmlinuz-3.0.0-12-generic这样的文件,这是linux核心文件,如果找到,记下(hd0,X)中的X值。假设找到(hd0,5)时,显示了文件夹中的文件。
然后用live cd 或者 live usb启动,在live cd的ubuntu的终端中依次输入以下命令(sda5中的“5”必须改成上面记录下来数值)(这两句需要验证):
如果/boot没有单独分区:
代码:
sudo grub-install --boot-directory=/mnt/boot /dev/sda
如果/boot单独分区,则:
sudo grub-install --boot-directory=/mnt /dev/sda
然后重新启动即可。
(以上这两句命令也可以解决安装ubuntu时grub安装位置不对,没有将grub安装到/dev/sda,造成启动时不出现ubuntu启动项直接进入windows的问题,不过需要自行确定sda5中的“5”改成什么数字。)
6,如果连linux核心文件都没有,那么,彻底重新安装吧