设为首页 收藏本站
查看: 740|回复: 0

[经验分享] Ubuntu启动中Grub Rescue的修复方法

[复制链接]

尚未签到

发表于 2018-5-6 13:50:39 | 显示全部楼层 |阅读模式
  Grub的引导错误通常会有如下错误提示:
   error:unknow filesystem
   grub rescue>

  故障原因分析:
已经发现下面几种操作会导致这种问题:
1、想删除ubuntu,于是直接在windows下删除/格式化了ubuntu所在的分区。
2、调整磁盘,利用工具合并/分割/调整/删除分区,使磁盘分区数目发生了变化。
3、重新安装系统,把linux安装到了新分区,原有分区已经格式化,但是没有重新安装grub2。
4、用ubuntu备份工具/衍生版制造工具等,把主分区回复成了8.X的老版本,结果老版本的grub是grub1,于是把grub2破坏掉了。
5、提取ubuntu分区的前512字节生成的引导文件ubuntu.bin不正确,造成错误引导,此问题和本文无关,只需要重新提取生成bin文件即可解决故障。
总归,是由于操作者不知道grub2分为两部分,一部分(一般情况下)写在了mbr上,另一部分写在了某个分区的/boot/grub目录(如果/boot单独分区,则直接写在对应分区的/grub目录)里面。由于上述操作,致使grub2的mbr里面的那一部分找不到/grub目录里面的那一部分了(或者那部分已经删除了)

  如果要彻底删除Grub引导菜单,可以在故障修复台下Shift+F10,输入命令
bootrec /fixmbr  和   bootrec /fixboot  或者用diskgenius软件重建mbr记录

  在grub rescue下用到的命令解释:
  set     查看环境变量,这里可以查看启动路径和分区
  ls       查看设备
  insmod   加载模块
  root    指定用于启动系统的分区,可设定grub启动分区
  prefix  设定grub启动路径

  
  以下方法是手动修复Grub2的方法
1.  先使用ls命令,找到Ubuntu的安装在哪个分区:
     grub rescue>ls
     会罗列所有的磁盘分区信息,比方说:
     (hd0),(hd0,msdos5),(hd0,msdos3),(hd0,msdos2),(hd0,msdos1)

2. 然后依次调用如下命令: X表示各个分区号码
     grub rescue>ls (hd0,X)/boot/grub
     如果都找不到的话,需要查一下是否因为Linux版本差异,造成grub的路径不对,例如直接ls(hd0,X)/grub等等。
     正常情况下,会列出来几百个文件,很多文件的扩展名是.mod和.lst和.img,还有一个文件是grub.cfg。假设找到(hd0,5)时,显示了文件夹中的文件,则表示Linux安装在这个分区。
ls(hd0,X)/  则会列出所有根分区的文件夹和文件。

3. 输入
     
grub rescue>set
        这个命令查看当前的设置,正确的显示如下。如果显示正确,以下步骤4中的前2项命令可以不用输入,直接输入第3项命令加载模块。

        root=hd0,msdos5
        prefix=(hd0,msdos5)/boot/grub

4. 调用如下命令:
    grub rescue>set root=(hd0,5)
    grub rescue>set prefix=(hd0,5)/boot/grub
    grub rescue>insmod /boot/grub/normal.mod  (或者用insmod normal命令)
5. 然后调用如下命令,就可以显示出丢失的grub菜单了。
    grub rescue>normal
6. 不过不要高兴,如果这时重启,问题依旧存在,我们还需要对grub进行修复。
    进入Linux之后,在命令行执行:
    sudo update-grub
    sudo grub-install /dev/sda  (这是安装grub在sda上,下面2个命令是安装在指定根分区)
    如果需要安装在指定根分区,需要采用一下方法
    sudo update-grub
     sudo mount /dev/sda5 /mnt
     sudo grub-install --force --root-director=/mnt /dev/sda5


   重启测试是否已经恢复了grub的启动菜单? 恭喜你恢复成功

以下步骤是对grub rescue故障的深度分析。
如果找不到正确的/grub目录,则尝试寻找是否有linux核心文件,则依次调用如下命令:

grub rescue>ls (hd0,X)/boot     (X表示各个分区号码)

找名字类似与vmlinuz-3.0.0-12-generic这样的文件,这是linux核心文件,如果找到,记下(hd0,X)中的X值。假设找到(hd0,5)时,显示了文件夹中的文件。
  然后用live cd 或者 live usb启动,在live cd的ubuntu的终端中依次输入以下命令(sda5中的“5”必须改成上面记录下来数值)
sudo mount /dev/sda5 /mnt
sudo grub-install --boot-directory=/mnt/boot /dev/sda
然后重新启动即可。
(以上这两句命令也可以解决安装ubuntu时grub安装位置不对,没有将grub安装到/dev/sda,造成启动时不出现ubuntu启动项直接进入windows的问题,不过需要自行确定sda5中的“5”改成什么数字。)
   如果连linux核心文件都没有,那么,彻底重新安装吧

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-456619-1-1.html 上篇帖子: PXE KICKSTART Ubuntu12.04 实战 下篇帖子: Linux(Ubuntu)设置环境变量(转载)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表