GithubHelp home page GithubHelp logo

mwoz123 / grub-btrfs Goto Github PK

View Code? Open in Web Editor NEW

This project forked from antynea/grub-btrfs

0.0 0.0 0.0 189 KB

grub-btrfs, Include btrfs snapshots at boot options. (Grub menu)

License: GNU General Public License v3.0

Shell 97.90% Makefile 2.10%

grub-btrfs's Introduction

GitHub release

grub-btrfs

This is a version 4.xx of grub-btrfs

BTC donation address: 1Lbvz244WA8xbpHek9W2Y12cakM6rDe5Rt

Description

Improves Grub by adding "btrfs snapshots" to the Grub menu.

You can start your system on a "snapshot" from the Grub menu.

Supports manual snapshots, snapper, timeshift ...

Warning : it isn't recommended to start on read-only snapshot

What does grub-btrfs v4.xx do :

  • Automatically List snapshots existing on root partition (btrfs).
  • Automatically Detect if "/boot" is in separate partition.
  • Automatically Detect kernel, initramfs and intel microcode in "/boot" directory on snapshots.
  • Automatically Create corresponding "menuentry" in grub.cfg
  • Automatically detect snapper and use snapper's snapshot description if available.
  • Automatically generate grub.cfg if you use the provided systemd service.

Installation :

Arch Linux

pacman -S grub-btrfs

Manual

  • Run make install or look into Makefile for instructions on where to put each file.

NOTE: Generate your Grub menu after installation for the changes to take effect.

On Arch Linux use grub-mkconfig -o /boot/grub/grub.cfg.

Customization:

You have the possibility to modify many parameters in /etc/default/grub-btrfs/config.

  • GRUB_BTRFS_SUBMENUNAME="Arch Linux Snapshots"

    Name appearing in the Grub menu.

  • GRUB_BTRFS_PREFIXENTRY="Snapshot:"

    Add a name ahead your snapshots entries in the Grub menu.

  • GRUB_BTRFS_DISPLAY_PATH_SNAPSHOT="true"

    Show full path snapshot or only name in the Grub menu, weird reaction with snapper.

  • GRUB_BTRFS_TITLE_FORMAT="p/d/n"

    Custom title, shows/hides p"prefix" d"date" n"name" in the Grub menu, separator "/", custom order available.

  • GRUB_BTRFS_LIMIT="50"

    Limit the number of snapshots populated in the GRUB menu.

  • GRUB_BTRFS_SUBVOLUME_SORT="descending"

    Sort the found subvolumes by newest first ("descending") or oldest first ("ascending").

    If "ascending" is chosen then

    the $GRUB_BTRFS_LIMIT oldest subvolumes will populate the menu.

  • GRUB_BTRFS_SHOW_SNAPSHOTS_FOUND="true"

    Show snapshots found during run "grub-mkconfig".

  • GRUB_BTRFS_SHOW_TOTAL_SNAPSHOTS_FOUND="true"

    Show Total number of snapshots found during run "grub-mkconfig".

  • GRUB_BTRFS_NKERNEL=("kernel-custom")

    Use it only if you have a custom kernel name

  • GRUB_BTRFS_NINIT=("initramfs-custom.img" "initrd.img-custom")

    Use it only if you have a custom initramfs name.

  • GRUB_BTRFS_INTEL_UCODE=("intel-ucode.img")

    Use it only if you have custom intel-ucode.

  • GRUB_BTRFS_IGNORE_SPECIFIC_PATH=("var/lib/docker")

    Ignore specific path during run "grub-mkconfig".

    For example:

    If path is a directory # Found Snapshot: 2016-03-31 10:24:41 var/lib/docker/btrfs/subvolumes/...

    use : GRUB_BTRFS_IGNORE_SPECIFIC_PATH=("var/lib/docker")

    If path is a subvolume : # Found Snapshot: 2016-03-31 10:24:41 @var/lib/docker/btrfs/subvolumes/...

    use : GRUB_BTRFS_IGNORE_SPECIFIC_PATH=("@var/lib/docker")

    You can combine them

    use : GRUB_BTRFS_IGNORE_SPECIFIC_PATH=("@var/lib/docker" "var/lib/docker")

  • GRUB_BTRFS_SNAPPER_CONFIG="root"

    Snapper's config name to use.

  • GRUB_BTRFS_DISABLE="false"

    Disable grub-btrfs.

  • GRUB_BTRFS_DIRNAME="grub"

    Name of the grub folder in /boot/, might be grub2 on some distributions.

  • GRUB_BTRFS_OVERRIDE_BOOT_PARTITION_DETECTION="false"

    Change to "true" if you have a boot partition in a different subvolume.

  • GRUB_BTRFS_MKCONFIG=grub-mkconfig

    Name or path of the 'grub-mkconfig' executable; might be 'grub2-mkconfig' on some distributions.

Automatically update grub

If you would like Grub to automatically update when a snapshot is made or deleted:

  • Mount your subvolume which contains snapshots to /.snapshots
  • Use systemctl start/enable grub-btrfs.path
  • grub-btrfs.path automatically (re)generates grub.cfg when a modification appears in /.snapshots

Special thanks for assistance and contributions

grub-btrfs's People

Contributors

antynea avatar anyc avatar cmlsharp avatar crafter6432 avatar daftaupe avatar hrotkogabor avatar luflosi avatar maximbaz avatar mrbliss avatar psykar avatar thomasfinstad avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.