Skip to main content

How to recover a root password in Red Hat-based Linux systems

Forgetting or never having the root password for a Linux system is a bad thing. This short how-to will prevent a time-consuming reinstall.
Image
How to recover a root password in Linux

Photo by Soonios Pro from Pexels

We’ve all inherited systems we didn’t have any part of building. If you are a systems administrator, the day will come when you need to work on a system and don’t have the root password for any number of reasons—and statistically speaking, that day will come at the worst possible moment: you need access to that box *right now*.

Recovering the root password might seem frightening, but it doesn’t have to be difficult or complicated. On a RHEL/CentOS version 7 or later system, thanks to the Grub bootloader it’s actually pretty simple.

  1. Begin by starting a kettle of water to boil (Optional, but recommended).

  2. First, you need console access: Either at a keyboard and monitor locally, or via Virtual Machine remote console, you will need to see and interact with the bootloader.

  3. Reboot the machine: As soon as the bootloader comes up with the selection screen, quickly tap the up and down arrows up and down to pause the countdown.

  4. Select the kernel you want to boot into, and hit 'e': This will take you into a screen where you can edit the grub bootloader script.

  5. Find the line that refers to the kernel: There will be a series of 'boot parameters' here: these are instructions passed during the loading of the kernel.

    1. For RHEL/CentOS 7, the line starts with 'linux16'.

    2. For RHEL/Centos 8x, and Fedora the line starts with 'linux'.

  6. Add 'rd.break' at the end of that line (There are other things you can do here, but for now, this is all you need) [ Note: This change is temporary ].

  7. Now hit Ctrl-x to run the edited bootloader script.

  8. You’ll boot to a 'rescue' prompt that looks like this: switch_root:/#.

  9. Remount the root partition in read-write mode so that you can run commands. Enter the following: mount -o remount rw /sysroot and then hit ENTER.

  10. Now type chroot /sysroot and hit enter. This will change you into the sysroot (/) directory, and make that your path for executing commands. 

  11. Now you can simply change the password for root using the passwd command.

  12. Next, before you reboot, you will need to make sure that SELinux allows the file changes. At the prompt ,enter: touch /.autorelabel. This will signal SELinux on the next reboot that the filesystem has changed (the changed password) and allow the change to be loaded. This will cause the whole filesystem to be 'relabeled' which might take a while, depending on the size of the filesystem and the speed of the machine, so be aware of this possibility.

  13. Type exit to leave the chroot environment and enter reboot.

  14. Go and make a cup of tea to reward yourself for your cleverness: The water should be boiling now. (Again, optional but recommended and highly dependent on your participation with Step #1.)

And that’s it. You should now have root password access to this system. 

Want to try out Red Hat Enterprise Linux? Download it now for free.

Topics:   Linux  
Author’s photo

Glen Newell

Glen Newell has been solving problems with technology for 20 years. As a Systems Engineer and administrator, he’s built and managed servers for Web Services, Healthcare, Finance, Education, and a wide variety of enterprise applications. More about me

Try Red Hat Enterprise Linux

Download it at no charge from the Red Hat Developer program.