How to Migrate From CentOS 7 to AlmaLinux 8

CentOS 7 reaches the end of life on June 30th, 2024 marking the end of the CentOS Project after CentOS 8 was prematurely discontinued back on December 31st in favor of CentOS Stream.

Thankfully, you can migrate from CentOS 7 to AlmaLinux 8 or any major Enterprise 8.x RHEL distributions such as Oracle Linux 8, Rocky Linux 8, or CentOS Stream 8 using the Elevate Project.

What is Elevate?

Elevate is a utility developed by AlmaLinux designed to facilitate the migration from CentOS 7 or any major versions of RHEL-based distros from 7.x to 8.x and from 8.x to 9.x. It provides the Leapp tool which initiates the actual upgrade process from one version to another.

The upgrade from CentOS 7 to any major RHEL-based distribution takes the following directions as illustrated in the diagram below.

Migrate CentOS 7 to AlmaLinux 8
Migrate CentOS 7 to AlmaLinux 8

If you are looking to switch from CentOS 7 to AlmaLinux 8, then you have come to the right place. In this guide, we will guide you on how to migrate from CentOS 7 to AlmaLinux 8 using the Elevate Project.

Preliminary Step

As is always recommended before migrating to any major release, it’s prudent to have a backup of your files in case something goes wrong during the upgrade. Therefore, take some time and take a backup copy of all the important files.

Step 1: Update CentOS 7 System

To get off the ground, log into your instance of CentOS 7 and upgrade the system to the latest version by running the following yum command.

$ sudo yum update
Update CentOS 7 Linux
Update CentOS 7 Linux

Once the update is complete, verify that CentOS 7 has been updated to the latest release as follows.

$ cat /etc/redhat-release
OR 
$ cat /etc/os-release

You should get the following as the output confirming that CentOS 7 has been updated to the latest release.

CentOS Linux release 7.9.2009 (Core)
Check CentOS 7 Linux
Check CentOS 7 Linux

Step 2: Install Elevate Repository in CentOS 7

The next step is to enable the Elevate repository on your CentOS 7 system by running the following command:

$ sudo yum install -y http://repo.almalinux.org/elevate/elevate-release-latest-el7.noarch.rpm
Enable Elevate Repository on CentOS 7
Enable Elevate Repository on CentOS 7

To confirm that Elevate has successfully been installed, run the following rpm command.

$ rpm -qi elevate-release

You should get the following output providing intricate details about the elevate-release package including the version, release, architecture, install date and so much more.

Confirm Elevate Repository
Confirm Elevate Repository

Step 3: Install Leapp Utility in CentOS 7

The Elevate repository provides the Leapp utility which facilitates the actual migration of Red Hat Enterprise Linux 7.x distributions to any Enterprise Linux 8.x releases.

For example to migrate from CentOS 7 to AlmaLinux 8, install the following software packages.

$ sudo yum install -y leapp-upgrade leapp-data-almalinux
Install Leapp in CentOS 7
Install Leapp in CentOS 7

Step 4: Migrate CentOS 7 to AlmaLinux 8

Once the migration packages have successfully been installed, run the pre-flight upgrade checklist using the following command:

$ sudo leapp upgrade

The utility performs a series of checks to confirm if the system is ready for the switch to AlmaLinux 8. The CentOS 7 has some inherent issues that prevent the migration from taking as seen in the error report as shown below.

Run Pre-Flight Check Upgrade
Run Pre-Flight Check Upgrade

The pre-upgrade report is generated and saved in the /var/log/leapp/leapp-report.txt file. From here, you can view all the issues that prevent the migration to AlmaLinux.

In our case, we ran into a couple of issues. Firstly, our system had two kernels; something which hampers the migration to AlmaLinux 8. Your system must have only one kernel.

To check the number of installed kernels, run the command:

$ rpm -q kernel
Check Installed Kernel
Check Installed Kernel

If your system has multiple kernels, as is our case, delete all and remain with only one using the following command.

$ sudo package-cleanup --oldkernels --count=1

Once again, verify the number of kernels present in your system as follows.

$ rpm -q kernel
Verify Installed Kernel
Verify Installed Kernel

To fix the remaining issues, run the following commands, which allow remote root login using the SSH protocol.

$ sudo echo PermitRootLogin yes | sudo tee -a /etc/ssh/sshd_config

Next, run the following command to remove the pam_pkcs11 module in the PAM configuration

$ sudo leapp answer --section remove_pam_pkcs11_module_check.confirm=True

Finally, disable the pata_acpi module.

$ sudo rmmod pata_acpi

This time around, we only have one kernel remaining, which is great!

After fixing all the issues, proceed and perform the migration from CentOS 7 to AlmaLinux 8 by running the following command:

$ sudo leapp upgrade

This is a lengthy process and takes quite some time. Upon successful execution of the command, a report will be generated, and this time around, all indication is that everything went according to plan.

Upgrade CentOS 7 to AlmaLinux 8
Upgrade CentOS 7 to AlmaLinux 8

Next, reboot your system.

$ reboot

On the GRUB menu, you will find the ‘Elevate-Upgrade‘ entry. Press ENTER.

Choose ELevate Upgrade
Choose ELevate Upgrade

The upgrade to AlmaLinux 8 will continue and the system will reboot a couple of times.

Upgrade to AlmaLinux 8
Upgrade to AlmaLinux 8

Finally, the login screen will come into view. Provide your password and click ‘Sign In’ or hit ENTER to log in.

Login to AlmaLinux 8
Login to AlmaLinux 8

On the terminal, verify the version of AlmaLinux using the command below.

$ cat /etc/redhat-release
Check AlmaLinux Version
Check AlmaLinux Version

Alternatively, run the command.

$ cat /etc/os-release
Check AlmaLinux Release
Check AlmaLinux Release

The output confirms that we have successfully switched or migrated from CentOS 7 to Almalinux 8.7.

Conclusion

In this guide, we have demonstrated how to migrate from CentOS 7 to AlmaLinux 8 using the Elevate project which is an application that helps simplify the switch from Enterprise 7.x systems to Enterprise 8.x.

Similar Posts