Upgrading Qubes R3.2 to R4.0

Before attempting either an in-place upgrade or a clean installation, we strongly recommend that users back up their systems.

Current Qubes R3.2 systems cannot be upgraded in-place to R4.0. A full backup, clean 4.0 install, and restore is required. This can be done by following the procedure below.

Preparation

  1. Go to downloads and prepare a USB drive or DVD with the R4.0 installer.

  2. If this is your only computer, and you do not have a R3.2 installer, you should also create a separate R3.2 USB drive or DVD installer at this time.

Backup R3.2

  1. Attach the backup drive you will be using. These steps assume it is a USB drive.

  2. Shutdown all non-essential VMs. Typically, sys-usb will be the only VM you need to leave running.

  3. Follow the Creating a Backup section in the Backup, Restoration, and Migration guide to back up all VMs except sys-usb.

  4. Verify the integrity of your backup by following the Restoring from a Backup section in the Backup, Restoration, and Migration guide and:

    • If you’re using Qubes Manager, check the box under “Restore options” that says, “Verify backup integrity, do not restore the data.”
    • If you’re using qvm-backup-restore from the command-line, use the --verify-only option.
  5. If your backup verifies successfully, proceed to the next section. If it does not, stop. Go back and repeat the backup steps, review the documentation or search the qubes-users mailing list, or ask for assistance on the qubes-users mailing list or IRC.

Install R4.0

This section provides general guidance on installing R4.0 as part of migrating from R3.2. For further details, please see the installation guide.

  1. Shut down R3.2 and boot the R4.0 installer.

  2. Follow the installation prompts until you get to the drive selection screen. Choose I want to make additional space available. Select the box at the top of the list in order to select all partitions. This will erase the entire drive, so do this only if Qubes is the only OS installed on your computer. If you did not successfully verify your backup in the previous section, cancel the installation, and go back to do that now.

  3. Complete the R4.0 installation. Ask for assistance on the qubes-users mailing list if you run into trouble.

  4. If you are unable to successfully install R4.0 on your system, all is not lost. Use the R3.2 installer to reinstall R3.2, then restore from your backup.

Restore from your backup

  1. Welcome to Qubes R4.0! The first thing you might notice is that Qubes Manager is not started by default. We won’t need it for the next step, but we will be starting it later.

  2. Since patches may have been released since your installation image was created, update Qubes R4.0 by going to the dom0 command line (Qubes menu -> Terminal Emulator) then running:

    sudo qubes-dom0-update
    
  3. Reboot dom0.

  4. Go to Qubes menu -> System Tools -> Qubes Manager to start it.

  5. Follow the Restoring from a Backup section in the Backup, Restoration, and Migration guide. We recommend that you restore only your TemplateBasedVMs and StandaloneVMs from R3.2. Using TemplateVMs and SystemVMs from R3.2 is not fully supported (see #3514). Instead, we recommend using the TemplateVMs that were created specifically for R4.0, which you can customize according to your needs. For the TemplateVM OS versions supported in R4.0, see Supported Versions. If the restore tool complains about missing templates, you can select the option to restore the AppVMs anyway, then change them afterward to use one of the default R4.0 templates.

Upgrade all Template and Standalone VM(s)

We strongly recommend that you update all TemplateVMs and StandaloneVMs before use so that you have the latest security patches from upstream distributions. In addition, if the default templates have reached EOL (end-of-life) by the time you install R4.0, we strongly recommend that you upgrade them before use. Please see Supported Versions for information on supported OS versions and consult the guides below for specific upgrade instructions: