JT
December 18 2024
Updated December 18 2024

How do I set a password on Grub?

Linux

It is often necessary to protect the device from various modifications and changes at a lower level. Whether it's loading recovery images that can work with the host file system on behalf of root, or editing kernel options at boot!

In this article we will look at one of the solutions to this problem, such as setting a password on Grub!

What is Grub?

Grub is a programme that takes control first after the BIOS/UEFI boot and allows you to define the image and settings that you want to run next. For example, this solution is useful when you have two or more operating systems or images on your device that can allow you to perform recovery work on the OS.

List of way to start
Screenshot №1 - List of way to start

Bootloader loading depends on which partition table disc is used to store it. For example, from an MBR partition table, the boot order is as follows:

BIOS → Selects the first 512 bytes of the boot area and transfers control (Stage 1) → Before bootloader configuration files are loaded (Stage 2) → Loads the kernel

With GPT partitions (refers more often to UEFI) booting is different:

UEFI → Search on EFI partition (usually /boot/efi) → Directly load bootloader.efi → Load kernel

An intruder can exploit the features and functionality of this solution to gain access to bypass security measures! As a countermeasure, consider installing a password on grub, which will close some of the vulnerabilities at its level.

How to set a password on Grub?

Authentication data for Grub is stored in the /etc/grub.d/ directory file and is a combination of login and hashed password. So to make a new one, we need to create an entry in the file. Beforehand, let's prepare the password with the grub-mkpasswd-pbkdf2 utility:

grub-mkpasswd-pbkdf2 | sudo tee -a /etc/grub.d/40_custom
Make password for load
Screenshot №2 - Make password for load

Let's go to the /etc/grub.d/ file and delete the extra lines that are left due to output redirection, and add a couple of lines about the user. As a result, we will get the following line at the end of the configuration file:

set superusers="username"

password_pbkdf2 username grub.pbkdf2.sha512.<long_hash>

Save pass
Screenshot №3 - Save pass

Let's explain each of the items in this context:

  • set superusers - sets the username to be considered superuser in the context of GRUB;
  • username - this is the username for which you set the password;
  • password_pbkdf2 - specifies that you should use PBKDF2 hash to verify the password;
  • username is the username for which you set the password;
  • grub.pbkdf2.sha512.<long_hash> is the password hash generated with grub-mkpasswd-pbkdf2. GRUB will compare the password entered by the user with this hash.

Then exit and save the file and compile the bootloader config from it:

sudo update-grub
Update config
Screenshot №4 - Update config

Restart the device and wait for the bootloader, then select one of the images:

Check
Screenshot №5 - Check

Great, the password protection works and will not let you boot into the OS without knowing the bootloader password. As a result of executing these commands you should get a list of parameters of the requested objects. If you don't have sufficient resources than you can perform actions on powerful cloud servers. Serverspace provides isolated VPS / VDS servers for common and virtualize usage.

Create Server
Screenshot №6 — Create Server
Vote:
5 out of 5
Аverage rating : 5
Rated by: 1
33145 North Miami, FL 2520 Coral Way apt 2-135
+1 302 425-97-76
700 300
ITGLOBAL.COM CORP
700 300

You might also like...

We use cookies to make your experience on the Serverspace better. By continuing to browse our website, you agree to our
Use of Cookies and Privacy Policy.