How to boot on a BTRFS snapshot

=> Comment on Mastodon

Introduction

I always wanted to have a simple rollback method on Linux systems, NixOS gave me a full featured one, but it wasn't easy to find a solution for other distributions.

Fortunately, with BTRFS, it's really simple thanks to snapshots being mountable volumes.

Setup

You need a Linux system with a BTRFS filesystem, in my examples, the root subvolume (where / is) is named gentoo.

I use btrbk to make snapshots of / directly in /.snapshots, using the following configuration file:

snapshot_preserve_min   30d
volume /
  snapshot_dir .snapshots
    subvolume .

With a systemd service, it's running once a day, so I'll have for 30 days of snapshots to restore my system if needed.

This creates snapshots named like the following:

$ ls /.snapshots/
ROOT.20230102
ROOT.20230103
ROOT.20230104

A snapshot address from BTRFS point of view looks like gentoo/.snapshots/ROOT.20230102.

I like btrbk because it's easy to use and configure, and it creates easy to remember snapshots names.

Booting on a snapshot

When you are in the bootloader (GRUB, systemd-boot, Lilo etc..), edit the command line, and add the new option (replace if already exists) with the following, the example uses the snapshot ROOT.20230102:

rootflags=subvol=gentoo/.snapshots/ROOT.20230103

Boot with the new command line, and you should be on your snapshot as the root filesystem.

Be careful

When you are on a snapshot, this mean any change will be specific to this volume.

If you use a separate partition for /boot, an older snapshot may not have the kernel (or its module) you are trying to boot.

Conclusion

This is a very simple but effective mecanism, more than enough to recover from a bad upgrade, especially when you need the computer right now.

Going further

There is a project grub-btrfs which can help you adding BTRFS snapshots as boot choices in GRUB menus.

=> grub-btrfs GitHub project page

Proxy Information
Original URL
gemini://perso.pw/blog//articles/boot-on-btrfs-snapshot.gmi
Status Code
Success (20)
Meta
text/gemini
Capsule Response Time
133.028088 milliseconds
Gemini-to-HTML Time
0.716581 milliseconds

This content has been proxied by September (ba2dc).