Difference between revisions of "How Linux Boots"
(→What can you do if your Linux does not Boot?) |
|||
Line 34: | Line 34: | ||
=== GRUB === |
=== GRUB === |
||
+ | |||
+ | When the GRUB boot-loader is working it will show you a menu for booting into all your installed OSs and will allow you to boot with an older kernel. When GRUB fails to load it will drop you into a prompt where you can try various commands, yet it is usually easier to fix your GRUB by booting with a Live-CD or USB-Stick. |
||
+ | |||
+ | When GRUB is working one can also "edit" the arguments that are passed to the kernel. This is often useful. (see below) |
||
+ | |||
+ | GRUB can be protected with a password so that one can only boot the default option and one is not able to pass different arguments to the kernel. |
||
+ | |||
+ | === Kernel command-line === |
||
+ | |||
+ | When you boot with grub you can specify arguments that are passed to the kernel. Those are usually of the form NAME=value or just some flag. |
||
+ | |||
+ | useful here are: |
||
+ | * root=/dev/sdb7 --- would try to use partition 7 of /dev/sdb as your root partition. |
||
+ | * init=/bin/bash --- instead of loading sytemd it will directly boot into just a shell. |
||
+ | |||
+ | See: [https://www.kernel.org/doc/html/v4.14/admin-guide/kernel-parameters.html kernel parameters] for more. |
Revision as of 18:35, 29 October 2020
Contents
Motivation
Nothing is more frustrating then not being able to boot into your system. If it hangs a boot with a cryptic message, then what do you do? People running other Operating Systems then tend to try to re-install their OS at this point. Once you know how Linux boots then it is almost always possible to boot into your system again as long as your hard-drive is not damaged.
Stages of Booting Linux
Simplified:
- your PC boots (BIOS from EEPROM chips on your motherboard. e.g when you press F12 during boot this is handled by the BIOS)
- loads the first ca 300 bytes from block 0 of your hard drive
- loads the rest of GRUB boot loader
- GRUB can readonly mount most filesystems and load kernel (vmlinuz) and initial-ramdisk (initrd)
- kernel unpacks itself and intializes hardware
- kernel unpacks initial ramdisk and starts script there (e.g. /init )
- initial ramdisk scripts loads additional modules and mount real /
- starts init process. (today usually systemd)
- systemd runs boot scripts for all configured items. (e.g. ssh, X11, ..) and mounts additional filesystems, ..
A few notes to the above:
- The BIOS is specific to PCs and this looks different on other hardware. E.g. Raspberry Pi and other ARM systems, etc..
- The initial boot blocks can also be loaded via network (PXE network boot).
- you can also directly boot a kernel without an initial ram-disk but that means that the kernel needs to have all necessary drives compiled in that are needed for at least reading the harddisk.
- systemd is still a bit controversial and there are distributions out there that try to avoid it. e.g. devuan.
- newer PCs support "UEFI/secure boot". Which does not offer much security but was intended to force the lock-in into proprietary operating systems. Most modern Linux Distributions can deal with UEFI-Boot but if you can turn this off in your BIOS settings it will make installing Linux much easier. For an overview of how the UEFI/SecureBoot works see: wiki.debian.org/SecureBoot
- when booting from CDrom there is a special syslinux bootloader used.
What can you do if your Linux does not Boot?
BIOS
When you do not even get to the Grub bootscreen then you have to check your BIOS. If you have more then 1 Harddrive you can select which one to use for boot and you can allow booting from CDrom or USB drive there. In some BIOS versions you can press F12 to select your boot device
GRUB
When the GRUB boot-loader is working it will show you a menu for booting into all your installed OSs and will allow you to boot with an older kernel. When GRUB fails to load it will drop you into a prompt where you can try various commands, yet it is usually easier to fix your GRUB by booting with a Live-CD or USB-Stick.
When GRUB is working one can also "edit" the arguments that are passed to the kernel. This is often useful. (see below)
GRUB can be protected with a password so that one can only boot the default option and one is not able to pass different arguments to the kernel.
Kernel command-line
When you boot with grub you can specify arguments that are passed to the kernel. Those are usually of the form NAME=value or just some flag.
useful here are:
- root=/dev/sdb7 --- would try to use partition 7 of /dev/sdb as your root partition.
- init=/bin/bash --- instead of loading sytemd it will directly boot into just a shell.
See: kernel parameters for more.