Skip to content
forked from ChimeraOS/frzr

A deployment and automatic update mechanism for operating systems

License

Notifications You must be signed in to change notification settings

BoukeHaarsma23/frzr

This branch is 65 commits ahead of ChimeraOS/frzr:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

93ff9b8 · Aug 27, 2024
Aug 18, 2024
Jun 24, 2024
Aug 18, 2024
Sep 21, 2019
Aug 25, 2024
Aug 24, 2024
Aug 24, 2024
Aug 24, 2024
Jul 31, 2024
Aug 27, 2024
Aug 18, 2024
Jul 31, 2024
Jul 31, 2024
Aug 23, 2024
Aug 22, 2024
Apr 22, 2021
Jun 22, 2024
Jul 31, 2024
Jul 31, 2024
Jun 22, 2024
Jun 24, 2024
Jun 22, 2024
Jul 31, 2024
Jun 22, 2024
Jun 22, 2024

Repository files navigation

frzr

frzr is a deployment and automatic update mechanism for operating systems.

It deploys pre-built systems that have been generated using btrfs send to snapshot a rootfs image.

Features

Despite frzr being the deployment software for chimeraos it has been designed to handle every linux distribution, even embedded ones or the more traditional ones.

Each distibution can either be immutable or read/write, immutable distros can choose how they want to achieve the goal and implement a distro-specific way of unlocking the filesystem.

frzr aims at:

  • ensuring safe and atomic updates that never interrupt the user
  • distributing a known tested and working copy of a system
  • allows easier transitioning among different operating systems and versions
  • allows installing one kernel that can be shared among all installed systems

How

Updated system images are downloaded at boot time and deployed to an entirely separate subvolume so as not to interfere with the currently running system. Upon next boot, the newly installed system is started and the old one is deleted, completely seamlessly and invisibly.

Actions to be performed when installing the system, unlocking it (if required) and uninstalling it are distro-specific and are provided via scripts that frzr runs when performing the requested action.

More

To ease system management and system debuggability frzr can be used to keep a primary distro on the main btrfs subvolume and manage deployments in a completely separate way so that your beloved archlinux install will remain usable whenever you want to.

Also frzr ships with utilities that are meant to regenerate bootloader entries whenever a kernel gets installed or uninstalled.

Q&A

Q Are there limitations on what systems can be deployed?

A Yes, supported systems must support booting from a btrfs subvolume.

Q Is the distro limited in what it can do once installed?

A Not by default, every limitation is decided by maintainers of that distro.

Q Is it easy to create a proof-of-concept distro that is compatible with frzr?

A Absolutely: frzr wants to be hackable and easy to work with in every aspect: just create a btrfs subvolume and run your preferred command to write a rootfs (debootstrap, pacstrap or whatever). Then create a snapshot of it with btrfs send and that file can be deployed on real hardware!

Q Are there rules to follow?

A There are conventions: for example a distro should NOT assume it's the only distro installed, and SHOULD NOT cause harm to other deployments for example by writing to the efi partition.

Q Can data be shared among different distributions?

A This depends on the distro: the easiest way probably is using systemd-homed and mount in /home the home directory.

About

A deployment and automatic update mechanism for operating systems

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 98.6%
  • Makefile 1.4%