Перейти к содержанию

How to deal with a kernel panic

Introduction

Sometimes, a kernel installation goes wrong, and you have to backtrack.

There can be many reasons for this, such as insufficient space on the /boot partition, an interrupted installation, or a problem with a third-party application.

Fortunately for us, there is always something we can do to save the day.

Try to reboot with the previous kernel

The first thing to try is to reboot with the previous kernel.

  • Restart the system.
  • Once you have reached the GRUB 2 boot screen, move the selection to the menu entry corresponding to the previous kernel and press the enter key.

Once the system has restarted, you can repair it.

If the system does not boot, try the rescue mode (see above).

Uninstall the broken kernel

The easiest way to do this is to uninstall the kernel version that is not working and then reinstall it.

Note

You cannot remove a kernel that you are running.

To show the version of the currently running kernel:

uname -r

To check the list of installed kernels:

dnf list installed kernel\* | sort -V

But the following command is perhaps more practical since it only returns packages with several versions installed:

dnf repoquery --installed --installonly

To remove a specific kernel, you can use dnf, specifying the kernel version you retrieved earlier:

dnf remove kernel-core-<version>

Example:

dnf remove kernel-5.14.0-427.20.1.el9_4.x86_64

or use the dnf repoquery command:

dnf remove $(dnf repoquery --installed --installonly --latest=1)

You can now upgrade your system and try reinstalling the latest kernel version.

dnf update

Reboot and see if the new kernel works this time.

Rescue mode

Rescue mode corresponds to the old single-user mode.

Note

To enter in rescue mode, you have to provide the root password.

To enter rescue mode, the easiest way is to select the line starting with 0-rescue-* in the grub menu.

Another way is to edit any line of the grub menu (pressing the 'e' key) and add systemd.unit=rescue.target at the end of the line that starts with linux and then press ctrl+x to boot the system into rescue mode.

Note

You are then in qwerty mode.

You can repair your system once you are in rescue mode and have entered the root password.

For that, you might need to configure a temporary IP address using ip ad add ... (see the network chapter of our admin guide).

Last chance: Anaconda Rescue Mode

If none of the above methods work, you can still boot from the installation ISO and repair the system.

This documentation does not cover this method.

System maintenance

Cleaning old kernel versions

You can remove old installed kernel packages, keeping only the latest version and version of the running kernel:

dnf remove --oldinstallonly

Limiting the number of installed kernel versions

We can limit the number of kernel versions by editing the /etc/yum.conf file and setting the installonly_limit variable:

installonly_limit=3

Note

You should always keep at least the latest kernel version and a backup version.

Author: Antoine Le Morvan

Contributors: Steven Spencer, Ganna Zhyrnova