Translation(s): English - Fran├žais - Italiano - Svenska

What is "downgrading a system"?

In Debian world, it means to move to an older distribution (typically, to move from unstable to testing). Do not expect to get anything stable by downgrading!

Is it supported?

So, what's the supported way?

  1. Make a backup of your system before you upgrade, so you can restore your backup to "downgrade" it!
  2. or re-install.

But I am desperate since I have no backup ...

There are some workarounds to save your system, provided you know where your important data is. They may be in your home directory, /etc/, /mail/, ....

  1. If an upgrade caused your system to break, boot your system with a live CD/USB-key etc., and make a backup of your private data somewhere (USB connected HDD, SSH connected remote system, ...).
  2. Make a fresh new system install.
  3. Restore your private data from the back up.

But I am desperate and lazy ...

Here is a totally unsupported trick which may work in some lucky situations. (Desktop focused example)

System downgrade tends to be more successful, if there aren't many packages installed. No GUI program and no TeX is good idea. I mean removing practically all non-essential packages is the trick :-) I know the following is very terse. If this is too cryptic, try the above method with live CD/USB-key, instead.

  1. Save data and stop all your Desktop tasks.
  2. CTRL-ALT-F3 to get to console and login as root.
  3. Start aptitude -u

  4. Press l to open a dialog.

  5. Enter ~i!~prequired!~pimportant!~pstandard!~M!~skernel!~sadmin!~n^firmware

  6. Press 'M' on 'Installed Packages' line and press '['.
  7. Press 'm' on key packages like 'vim' 'mc' 'git' 'ssh' 'exim4-daemon-light' ... (packages you need to keep.)
  8. Press '+' on key packages to be installed.
  9. Press '+' again if key packages show 'B' to resolve broken dependency.
  10. Press 'g' (resolve broken dependency as needed) to remove all non-essential packages.
  11. Exit aptitude.

  12. Edit /etc/apt/sources.list to point repository to the downgraded distribution.

  13. Set apt_preferences(5) to set the downgraded distribution with PIN 10001

  14. Run "apt update; apt full-upgrade" to downgrade system.

  15. Run aptitude -u to interactively resolve issues.

  16. Remove apt_preferences(5) PIN.

  17. Run aptitude -u and install system. (Use task list in aptitude and information from backed up /var/lib/dpkg/status.)

  18. If you are lucky, you may have somewhat functioning system. No guarantee of stability!!!

Chroot option

Sometimes it is easier and cleaner to use chroot multiply installations option. This option works for one partition linux install and allows you not just chroot into folder but hot swap currently installed linux.

Idea is to install all chroot linux OS you want into separate chroot folder like /bullseye /bookworm /clearlinux /ubuntu16.20 and then hot swap chroot folder content into your current root /.

This is risky, can fail, or destroy all your data and not guaranteed to work on your system. But practically works!

Here are a little bit technical details. To hot swap running OS your need special statically linked binary which can work without system /lib/libc.* libraries or any system binaries. Because when you move your /lib or /bin folder into /backup folder on running OS all system calls will fail and unable to complete any operations but kernel level ones. At this moment it can fail your system badly but it will not fail if you do all move operations at once using statically linked binary.

To try it on your system you will need two scripts:

then prepare chroot using debootstrap, to the new folder 'debootstrap bullseye /bullseye', install kernel and grub, then:

# 'swapos /bullseye'

# reboot

Here are more safer technique including booting into Live USB then swap all files manually from one folder to another and then reboot. But it takes much longer time and requires you to have external device connected to your PC and several reboots.

CategorySystemAdministration CategoryPackageManagement