Repair Linux boot failures in GRUB 2 rescue mode
As GRUB 2's ability to fix boot problems has greatly improved over the original GRUB bootloader. This article provides you with information on available options for repairing GRUB 2 boot issues and specific instructions on how to use the GRUB 2 terminal. The instructions are written for GRUB 2.
How it looks?
There are basically three error messages or screens when GRUB fails to boot.
grub>: This is the screen mode you see when GRUB has found everything except the configurationn file. This file probably will be grub.conf.
grub rescue>: This is the mode when GRUB 2 is unable to find the GRUB folder or its contents are missing/corrupted. The GRUB 2 folder contains the menu, modules and stored environmental data.
GRUB: Just "GRUB" nothing else indicates GRUB 2 failed to find even the most basic information needed to boot the system.
These are the basic errors that may occur during booting. Although there are a few more errors that can be seen on the screen like frozen splash screen, Busybox or Initramfs: GRUB 2 began....
But each of the GRUB 2 failure modes can be corrected either from GRUB 2 terminal or the Live boot CD or DVD of the distro, there are also 3rd party rescue tools available out there.
Basic commands available.
These are the commands that can be used when you enter the GRUB 2 terminl mode by pressing "c".
boot (Initiate the boot, also F10 or CTRL-x)
cat (view the contents of config or txt files; cat (hd0,1)/boot/grub/grub.cfg)
configfile (Load a GRUB 2 configuration file such as grub.cfg; configfile (hd0,5)/boot/grub/grub.cfg.)
initrd (Loads the initrd.img, necessary for booting; initrd (hd0,5)/initrd.img.)
insmod (Loads a module; insmod (hd0,5)/boot/grub/normal.mod, or insmod normal.)
linux (Loads the kernel; insmod /vmlinuz root=(hd0,5) ro.)
loop (Mount a file as a device; loopback loop (hd0,2)/iso/my.iso.)
ls (lists the contents of a partition/folder; ls, ls /boot/grub, ls (hd0,5)/, ls (hd0,5)/boot.)
lsmod (List loaded modules.)
normal (Activate the normal module, if loaded.)
search (Search for a device. Type help search for the available options.)
set (Review current settings, or set XXX to set a variable such as colors, prefix, root.)
vbeinfo (Display GRUB 2 available resolutions.)
The Rescue Shell.
If you get a rescue shell, this usually means that GRUB failed to load the "normal" module for some reason. It may be possible to work around this temporarily: for instance, if the reason for the failure is that "prefix" is wrong (perhaps it refers to the wrong device, or perhaps the path to "/boot/grub" was not correctly made relative to the device), then you can correct this and enter normal mode manually: Inspect the current prefix (and other preset variables):
set
You will probably have an output more or less like this:

Your output may differ but you get the information required. Find out which devices are available:
ls

Set to the correct value, which might be something like this:
set prefix=(hd0,1)/grub
(this has to be done according to your own drive name)
set root=(hd0,1)
(this has to be performed according to your own drive name.)
insmod normal
normal
The above commands will get you out of the rescue mode to the normal terminal mode. In the terminal mode you have more commands with increased functionality.
After the above commands you can go ahead and start the rest of the settings.
insmod linux
* linux /vmlinuz root=/dev/sdXY ro
(if this doesn't work try this)
linux /boot/vmlinuz-3.2.0-14-generic root=/dev/sda1 ro
(optional)
initrd /initrd.img
(Selects the initrd image.)
boot
After Booting the system.
Update the GRUB config file.
sudo update-grub
Reinstallation of Grub on the device:
sudo grub-install /dev/sdX
This should be it for the rescue part and your system should be good and running. If not you can save all your trouble by using Boot Repair. This is the tool used to repair your complete boot menu. It can be downloaded directly and used as a Live Boot CD or DVD. Here is the download link.
Suggested articles
21 Comment(s)
Comments
After I type insmod normal it says error:file not found. What did I do wrong?
use "ls <drive>/"
You can snoop around and see where your boot directory resides.
I had to do this for insmod normal to work
set prefix=(hd0,1)/boot/grub
After I type insmod normal I get:
error: invalid arch-independent ELF magic.
What does this mean and can it be fixed.
You lost me after the 'set' command. What is the "information required"? After the 'ls' command you say to set to the correct value. What is the correct value? Also, what is 'my own drive name'?
I appreciate you posting this procedure but could you post it for a much dumber audience. Thanks.
Getting this:
[email protected]:/$ sudo update-grub/usr/sbin/grub-probe: error: failed to get canonical path of `/cow'[email protected]:/$ sudo grub-install /dev/sda3Installing for i386-pc platform.grub-install: error: failed to get canonical path of `/cow'.
Type insmod show no module specified
Great webpage. I didn't know anything about Linix, but with your commands till: insmod normal normal
I could start up my Qimo kids linux again and with the update grub config file en reinstallation of grub, my windows Xp and Linux is working again. Thank you very much
after windows install it went to grub emergency, nothing worked, with the LS or Set commands, i thought my partitions were screwed.
Then i ran the following as a last resort from the howtogeek page and it worked
sudo apt-add-repository ppa:yannubuntu/boot-repair sudo apt-get update sudo apt-get install -y boot-repair boot-repair
then open boot-repair and repair disk
Hi, help... . I was in Windows Vista, trying to merge partitions because after getting updates for Ubuntu, the machine would take me to the usual login screen, but only showed black and white stripes on screen. But wouldn't bring my Ubuntu desktop back up.
I rebooted, and grub rescue mode,
grub rescue
is displayed, however I'm not able to use any of the commands that I'm aware of from Ubuntu forums, and I am sorely very inexperienced as my machine has run for nearly four years without any problems at all.
Thanks man, I was totally stuck this was my first install of Linux.
None of the partitions have the filesystem. What do I do?
thanks ..... finally almost was going to reformat that saved me as always good contributions last look and look until I found you because all pointed to / boot / grub that was the downside has a 10 ... x10 .......... ...............
it's not working in boss linux
using open suse tumbweed windows boot was removed by an up grade wth out any information to that regard so after some time and with my udual decorum i deleted the entire system after grub2 refused to reconise a cd install of win 7 , befor i inves any time in hunting down thoses responcable for the removal of win compateably in grib 2 and resoundly giving them a thrashing how do to get gurb2 out of the way an add joy was to find it also seems to have changed the ever faithful ,save me , system inderpendant the bios from reconising the win 7 boot cd open suse/grub your a socapath
The graphical way. Insert your Ubuntu CD, reboot your computer and set it to boot from CD in the BIOS and boot into a live session. You can also use a LiveUSB if you have created one in the past.
Hi Gurujyot_singh!
Thanks a lot for this post! I have a server running Debian 8 with qmail/tinydns (qmailrocks) and roundcube. After a simple upgrade, I decided to restart the machine and what surprise! It stops at this grub2 screen. It freezes any belly, isn't it? I was on lucky because I found this post and the services are used only on work time and this step was done at night. So, I could fix it on time!
Again, thanks a lot for this post because it is very simple and clear to read and understand! You wrote like a boss! Forgive me about my english..
grub rescue>set prefix=(hd0,msdos1)/boot/grub
This returns a "could not read or write outside of disk 'hd0'
what is this? thanks!
Just had this problem, tried all these recommended set commands; set prefix=bla bla bla, even tried booting from a usb device, nothing worked. So I thought the hard drive was knackered opened up the desktop case,pushed the hardrive power supply and data cables in a bit. Closed the case and powered the desktop backup and to my surprise, the desktop booted up successfully.
Hello,
I can see no date on this page and suppose it is not obsolete.
I am currently trying to use my previous dual boot disk (Debian 8 / Windows 8.1 64 bits) through USB in a new computer with Windows 10 only. Is it possible? Windows 10 only shows me the Debian 8 entry (not the Windows 8.1) and if I choose it I just get the grub rescue prompt with no idea as to what to do.
Any hint?
English |
Deutsch