3 Preparing the upgrade #
Before starting the upgrade procedure, make sure your system is properly prepared. Among other things, preparation involves backing up data and checking the release notes. The following chapter guides you through these steps.
3.1 Make sure the system is up-to-date #
   
   Upgrading the system is only supported from the most recent patch level.
   Make sure the latest system updates are installed by
   either running zypper
   patch or by starting the YaST module
   .
  
Mid 2023, the SUSE Linux Enterprise 15 product family switched over from a RSA 2048-bit signing key to a new RSA 4096-bit key. This change covers RPM packages, package repositories and ISO signatures. Old repositories that are not updated anymore and RPMs released up to the switch-over date, will remain signed with the old 2048-bit key.
If you update your system, the new key is automatically imported into the RPM keyring from the suse-build-key package on SLE 15 SP 4 and SP5 as well as the LTSS versions of SLE 15 SP1, SP2 and SP3.
If the key has not been imported yet, you can manually import it with:
>sudorpm --import /usr/lib/rpm/gnupg/keys/gpg-pubkey-3fa1d6ce-63c9481c.asc
If you are running an older version of SLE or did not import the new key, you will be asked to trust it during the upgrade. Make sure the fingerprint matches:
pub rsa4096/0xF74F09BC3FA1D6CE 2023-01-19 [SC] [expires: 2027-01-18] Key fingerprint = 7F00 9157 B127 B994 D5CF BE76 F74F 09BC 3FA1 D6CE uid SUSE Package Signing Key <build@suse.de>
Additionally, a reserve 4096-bit RSA key for disaster recovery purposes was imported:
pub rsa4096/0xA1BFC02BD588DC46 2023-01-19 [SC] [expires: 2033-01-16] Key fingerprint = B56E 5601 41D8 F654 2DFF 3BF9 A1BF C02B D588 DC46 uid SUSE Package Signing Key (reserve key) <build@suse.de>
This key can be manually imported using:
>sudorpm --import /usr/lib/rpm/gnupg/keys/gpg-pubkey-d588dc46-63c939db.asc
Both keys can also be found on the installation media and the SUSE website at https://www.suse.com/support/security/keys/.
3.2 Read the release notes #
   Find a list of all changes, new features, and known issues in the
   release notes.
   You can also find the release notes on the installation media in the
   docu directory.
  
The release notes usually only contain the changes between two subsequent releases. If you are skipping one or more Service Packs, check the release notes of the skipped Service Packs as well.
Consult the release notes to check whether the following applies:
- Your hardware needs special considerations 
- Any currently used software packages have changed significantly 
- Your installation requires special precautions 
3.3 Make a backup #
   Before upgrading, back up your data by copying the existing configuration
   files to a separate medium (such as tape device, removable hard disk, etc.).
   This primarily applies to files stored in /etc and some
   directories and files in /var and
   /opt. You may also want to write the user data in
   /home (the HOME directories) to a backup
   medium.
  
   Back up all data as root. Only root has sufficient permissions
   for all local files.
  
   
   If you have selected  as the
   installation mode in YaST, you can choose to do a (system) backup at a
   later point in time. You can choose to include all modified files and files
   from the /etc/sysconfig directory. However, this is not
   a complete backup, as all the other important directories mentioned above
   are missing. Find the backup in the /var/adm/backup
   directory.
  
3.4 Check the available disk space #
Software tends to grow from version to version. Therefore, take a look at the available partition space before updating. If you suspect you are running short of disk space, back up your data before increasing the available space by resizing partitions, for example. There is no general rule regarding how much space each partition should have. Space requirements depend on your particular partitioning profile and the software selected.
During the update procedure, YaST will check how much free disk space is available and display a warning to the user if the installation may exceed the available amount. In that case, performing the update may lead to an unusable system! Only if you know exactly what you are doing (by testing beforehand), you can skip the warning and continue the update.
3.4.1 Checking disk space on non-Btrfs file systems #
    Use the df command to list available disk space. For
    example, in Example 3.1, “List with df -h”, the root partition is
    /dev/sda3 (mounted as /).
   
df -h #Filesystem     Size  Used Avail Use% Mounted on
     /dev/sda3       74G   22G   53G  29% /
     tmpfs          506M     0  506M   0% /dev/shm
     /dev/sda5      116G  5.8G  111G   5% /home
     /dev/sda1       39G  1.6G   37G   4% /windows/C
     /dev/sda2      4.6G  2.6G  2.1G  57% /windows/D3.4.2 Checking disk space on Btrfs root file systems #
    On a Btrfs file system, the output of df can be
    misleading, because in addition to the space the raw data allocates, a
    Btrfs file system also allocates and uses space for metadata.
   
    Consequently a Btrfs file system may report being out of space even though
    it seems that plenty of space is still available. In that case, all space
    allocated for the metadata is used up.  For
    more information refer to man 8
     btrfs-filesystem and
    https://btrfs.wiki.kernel.org/index.php/FAQ.
   
    When using Btrfs for root file systems on your machine, make sure there is
    enough free space. Check the available space on all mounted partitions. In
    the worst case, an upgrade needs as much disk space as the current root
    file system (without /.snapshot) for a new snapshot.
   
The following recommendations have been proven:
- For all file systems, including Btrfs, you need enough free disk space to download and install big RPMs. The space of old RPMs is only freed after new RPMs are installed. 
- For Btrfs with snapshots, you need as a minimum as much free space as your current installation takes. We recommend having twice as much free space as the current installation. - If you do not have enough free space, you can try to delete old snapshots with - snapper:- #- snapperlist- #- snapperdelete NUMBER- However, this may not help in all cases. Before migration, most snapshots occupy only little space. 
3.5 Listing installed packages and repositories #
You can save a list of installed packages; for example, when doing a fresh install of a new major SLE release or reverting to the old version.
Be aware that not all installed packages or used repositories are available in newer releases of SUSE Linux Enterprise. Some may have been renamed and others replaced. It is also possible that some packages are still available for legacy purposes while another package is used by default. Therefore, some manual editing of the files might be necessary. This can be done with any text editor.
- Create a file named - repositories.bak.repocontaining a list of all used repositories:- #- zypperlr -e repositories.bak
- Also create a file named - installed-software.bakcontaining a list of all installed packages:- #- rpm-qa --queryformat '%{NAME}\n' > installed-software.bak
- Back up both files. The repositories and installed packages can be restored with the following commands: - #- zypperar repositories.bak.repo- #- zypperinstall $(cat installed-software.bak)Note: Number of packages increases with an update to a new major release- A system upgraded to a new major version (SLE X+1) may contain more packages than the initial system (SLE X). It will also contain more packages than a fresh installation of SLE X+1 with the same pattern selection. Reasons for this are: - Packages were split to allow a more fine-grained package selection. For example, 37 texlive packages on SLE 11 were split into over 3000 packages on SLE 15. 
- When a package has been split, all new packages are installed in the upgrade case to retain the same functionality as the previous version. However, the new default for a fresh installation of SLE X+1 may be to not install all packages. 
- Legacy packages from SLE X may be kept for compatibility reasons. 
- Package dependencies and the scope of patterns may have changed. 
 
3.6 Disable the LTSS extension #
   If you upgrade a SUSE Linux Enterprise Desktop system with Long Term Service Pack Support
   (LTSS) to a version that is still under general support, the upgrade will
   fail with the error No migration available. This happens
   because zypper migration tries to migrate
   all repositories, but there is no LTSS repository for
   the new version yet.
  
To fix this issue, disable the LTSS extension before the upgrade.
- Check if the LTSS extension is enabled: - >- sudoSUSEConnect --list-extensions | grep LTSS SUSE Linux Enterprise Server LTSS 12 SP4 x86_64 (Installed) Deactivate with: SUSEConnect -d -p SLES-LTSS/12.4/x86_64
- Disable the LTSS extension with the command from the - SUSEConnectoutput above:- >- sudoSUSEConnect -d -p SLES-LTSS/12.4/x86_64 Deregistered SUSE Linux Enterprise Server LTSS 12 SP4 x86_64 To server: https://scc.suse.com/
- Verify the LTSS repository is no longer present with - zypper lr.
3.7 Create non-MD5 server certificates for Java applications #
As a security measure, MD5-based certificates are no longer supported in Java. If you have certificates created as MD5, re-create your certificates with the following steps:
- Open a terminal and log in as - root.
- Create a private key: - #- opensslgenrsa -out server.key 1024- If you want a stronger key, replace - 1024with a higher number, for example,- 4096.
- Create a certificate signing request (CSR): - #- opensslreq -new -key server.key -out server.csr
- Self-sign the certificate: - #- opensslx509 -req -days 365 -in server.csr -signkey server.key -out server.crt
- Create the PEM file: - #- catserver.key server.crt > server.pem
- Place the files - server.crt,- server.csr,- server.key, and- server.pemin the respective directories where the keys can be found. For Tomcat, for example, this directory is- /etc/tomcat/ssl/.
3.8 Shut down virtual machine guests #
If your machine serves as a VM Host Server for KVM or Xen, make sure to properly shut down all running VM Guests prior to the update. Otherwise you may not be able to access the guests after the update.
3.9 Adjust your SMT client setup #
If the machine you want to upgrade is registered as a client against an SMT server, take care to do the following:
   Check if the version of the clientSetup4SMT.sh script on
   your host is up to date. clientSetup4SMT.sh from older
   versions of SMT cannot manage SMT 12 clients. If you apply software
   patches regularly on your SMT server, you can always find the latest
   version of clientSetup4SMT.sh at
   <SMT_HOSTNAME>/repo/tools/clientSetup4SMT.sh.
  
In case upgrading your machine to a higher version of SUSE Linux Enterprise Desktop fails, deregister the machine from the SMT server as described in Procedure 3.1. Afterward, restart the upgrade process.
- Log in to the client machine. 
- The following step depends on the current operating system of the client: - For SUSE Linux Enterprise 11, execute the following commands: - >- sudosuse_register -E- >- sudorm -f /etc/SUSEConnect- >- sudorm -rf /etc/zypp/credentials.d/*- >- sudorm -rf /etc/zypp/repos.d/*- >- sudorm -f /etc/zypp/services.d/*- >- sudorm -f /var/cache/SuseRegister/*- >- sudorm -f /etc/suseRegister*- >- sudorm -f /var/cache/SuseRegister/lastzmdconfig.cache- >- sudorm -f /etc/zmd/deviceid- >- sudorm -f /etc/zmd/secret
- For SUSE Linux Enterprise 12, execute the following commands: - >- sudoSUSEConnect --de-register- >- sudoSUSEConnect --cleanup- >- sudorm -f /etc/SUSEConnect- >- sudorm -rf /etc/zypp/credentials.d/*- >- sudorm -rf /etc/zypp/repos.d/*- >- sudorm -f /etc/zypp/services.d/*
 
- Log in to the SMT server. 
- Check if the client has successfully been deregistered by listing all client registrations: - >- sudosmt-list-registrations
- If the client's host name is still listed in the output of this command, get the client's - Unique IDfrom the first column. (The client might be listed with multiple IDs.)
- Delete the registration for this client: - >- sudosmt-delete-registration -g UNIQUE_ID
- If the client is listed with multiple IDs, repeat the step above for each of its unique IDs. 
- Check if the client has now successfully been deregistered by re-running: - >- sudosmt-list-registrations
3.10 IBM Z: Adjust zipl for UEFI Secure Boot #
      When upgrading from SUSE Linux Enterprise Server 12, enabling UEFI Secure Boot during or after the
      upgrade with yast bootloader will fail with an error:
    
Error: Could not install Secure Boot IPL records: Missing signature in image file /boot/zipl/image.prev /sbin/zipl: Failed /usr/sbin/grub2-install: error: `grub2-zipl-setup' failed.
      This happens because /boot/zipl still contains the previous, unsigned
      kernel and initrd as fallback in case the new kernel does not boot. To avoid this error, edit
      /etc/default/grub and change SUSE_SECURE_BOOT=1 to
      SUSE_SECURE_BOOT=auto. This setting makes zipl write a
      signature for the new kernel but not yield an error for the old kernel. Then run
      grub2-install to re-install the boot loader.
    
      Alternatively you can remove the obsolete kernel and initrd files from
      /boot/zipl manually. Only do so when you have already rebooted into the
      new kernel after the upgrade.
    
      After the next SUSE Linux Enterprise 15 kernel update, you can switch back to
      SUSE_SECURE_BOOT=1 to ensure all kernels are signed.
    
      For more information, refer to man 8 zipl and the IBM documentation at
      https://www.ibm.com/docs/en/linux-on-systems?topic=loader-parameters.
    
3.11 Adjust the resume boot parameter #
   On systems that have been installed with SUSE Linux Enterprise Desktop 12 or older, the default  kernel command
   line in /etc/default/grub may contain a resume
   parameter using a device node name such as /dev/sda1 to refer to the
   hibernation (suspend-to-disk) device. As device node names are not persistent and may
   change between reboots, fixing this is highly recommended. Otherwise, the upgraded system
   may hang on reboot.
  
- Find the hibernation device: - >- sudo- grep resume /etc/default/grubGRUB_CMDLINE_LINUX_DEFAULT="resume=/dev/sda1 splash=silent quiet showopts"- The hibernation device is - /dev/sda1. If the command returns nothing, hibernation is not configured.
- Get the UUID for - /dev/sda1:- >- sudo- blkid /dev/vda1/dev/vda1: UUID="a1d1f2e0-b0ee-4be2-83d5-78a98c585827" TYPE="swap" PARTUUID="000134b5-01"- The UUID for - /dev/sda1is- a1d1f2e0-b0ee-4be2-83d5-78a98c585827.
- Edit - /etc/default/gruband adjust the resume parameter. Replace- /dev/sda1with- UUID=a1d1f2e0-b0ee-4be2-83d5-78a98c585827. The result will look like this:- GRUB_CMDLINE_LINUX_DEFAULT="resume=UUID=a1d1f2e0-b0ee-4be2-83d5-78a98c585827 splash=silent quiet showopts" 
- Update the configuration of the grub boot manger: - >- sudo- grub2-mkconfig -o /boot/grub2/grub.cfg
If the system does not use hibernation, you can simply remove the resume parameter and update the boot configuration.