由于分区调整引起分区号或分区UUID改变造成的grub2不能正常启动 己安装好系统,对硬盘再次进行分区调整时可能会改变现有分区的分区号发生变化, 或者某种原因改变启动分区的UUID,都会造成grub2不能正常启动,而启动进入修复 模式(grub rescue),这时就要对grub进行修复。 1)用ubuntu9.10以后的版本的livecd光盘启动,进入试用桌面系统后,再修复grub,操作方法如 第一种情况的第二种方法— 2)在rescue模式下启动并修复 由于分区问题,启动时会自动进入rescue模式,只要grub核心文件还在分区内,就能 由rescue模式转到normal模式,进而通过命令进入系统。下面这个就是rescue介面: 由于在rescue模式下,只有少量的基本命令可用,必须通过一定的操作才能加载正常 模块,然后进入正常模式。 rescue模式下可使用的命令有:set,ls,insmod,root,prefix(设置启动路径) 先假设grub2的核心文件在(hd0,8)分区,再来看看怎样从rescue模式进入从(hd0,8)启 动的正常模式(normal)。 在rescue模式下search命令不能用,对不清楚grub2文件处于哪个分区的,可以用ls命 令查看,比如 ls (hd0,8)/ 查看(hd0,8)分区根目录,看看有没有boot文件夹 ls (hd0,8)/boot/ 查看(hd0,8)分区的/boot目录下文件 ls (hd0,8)/boot/grub/ 查看(hd0,8)分区/boot/grub目录下文件 通过文件查看,可以确定grub2核心文件处于哪个分区,接下来就可以进行从rescue到 normal的转变动作: 先 ls 看看分区,根据分区列表,猜下 / 分区的编号再 ls (hd0,x)/ 看分区目录下文件确 定找到 / 分区,不对的话继续找。找到 / 分区的 (hd0,x) 继续 grub rescue>root=(hd0,x) grub rescue>prefix=/boot/grub grub rescue>set root=(hd0,x) grub rescue>set prefix=(hd0,x)/boot/grub grub rescue>insmod normal rescue>normal -------->若出现启动菜单,按c进入命令行模式 rescue>linux /boot/vmlinuz-xxx-xxx root=/dev/sdax rescue>initrd /boot/initrd.img-xxx-xxx rescue>boot 内 核版本号 -xxx-xxx可以按Tab键查看后再手动补全。 有 /boot分区的,要先找出 /boot 分区 (hd0,x),再找出 / 分区的 (hd0,y),同样用 ls (hd0,x)/ 和 ls (hd0,y)/ 的方式确定分区 grub rescue>root=(hd0,x) grub rescue>prefix=/grub grub rescue>set root=(hd0,x) grub rescue>set prefix=(hd0,x)/grub grub rescue>insmod normal rescue>normal -------->若出现启动菜单,按c进入命令行模式 rescue>linux /vmlinuz-xxx-xxx root=/dev/sday rescue>initrd /initrd.img-xxx-xxx rescue>boot 说明: 1)由于grub2版本的的不一致,有的可能在第9步insmod normal.mod加载正常模块后 直接进入normal模式,即出现了normal grub>的提示符,这种情况就不能执行第10 步,即可以跳过normal命令的输入。 2)虽然输入normal命令会出现菜单,但由于缺少加载内核的Linux命令,直接从菜单 不能进入系统,需要按c在命令行继续操作。 3)使用/boot单独分区的,要正确修改路径,如 prefix=(hd0,8)/grub insmod /grub/normal.mod 另外root=/dev/sda8也要修改根分区的分区号。 4)按boot启动系统后,再在系统下打开终端,执行命令修复grub 重建配置文件grub.cfg sudo update-grub 重建grub到第一硬盘mbr sudo grub-install /dev/sda
无法开机,显示GRUB RESCUE
最新推荐文章于 2024-10-05 16:04:52 发布