Skip to main content

Snapshot Manager

Project description

Snapm CI License Ask DeepWiki

Snapm

Snapshot manager (snapm) manages named snapshot sets on Linux systems. Each snapshot set captures coordinated snapshots across multiple volumes, representing a consistent point-in-time system state that can be referenced and managed as a single unit.

Features

  • Coordinated snapshot sets: Create coordinated snapshots across multiple volumes
  • Bootable snapshots: Generate boot entries for snapshot boot and failsafe revert
  • Multiple backends: Support for LVM2 (Copy-on-Write and Thin) and Stratis
  • Flexible scheduling: Integration with systemd timers for automated snapshot creation with retention policies
  • Size policies: Flexible snapshot sizing with multiple strategies
  • Plugin architecture: Extensible design for additional storage backends

Quick Start

Installation

From RPM (Fedora/CentOS/RHEL)

Install from distribution repositories (when available):

dnf install snapm boom-boot

Manual Installation

  1. Create and activate a virtual environment:
python3 -m venv --system-site-packages .venv && source .venv/bin/activate
  1. If boom-boot is not installed from your distribution's packages, clone and install it with pip:
git clone https://github.com/snapshotmanager/boom-boot.git
cd boom-boot
python3 -m pip install .
  1. Repeat the process with the snapm repository:
git clone https://github.com/snapshotmanager/snapm.git
cd snapm
python3 -m pip install .

Basic Usage

Create a bootable snapshot set

Create a snapshot set named "before-upgrade" of root and home, with snapshot boot and revert boot entries:

snapm snapset create --bootable --revert before-upgrade / /home

List snapshot sets

snapm snapset list

Show detailed information:

snapm snapset show before-upgrade

Boot into a snapshot

  • Reboot and select the snapshot boot entry from the GRUB menu
  • Entry will be named: "Snapshot before-upgrade YYYY-MM-DD HH:MM:SS (version)"
  • Optionally run grub2-reboot <title> to pre-select snapshot boot entry, e.g.:
grub2-reboot "Snapshot before-upgrade YYYY-MM-DD HH:MM:SS (version)"
  • Use grub-reboot instead of grub2-reboot on Debian and Ubuntu systems.

Revert to snapshot state

snapm snapset revert before-upgrade

Then reboot into the Revert boot entry.

Note: Reverting destroys the snapshot set (snapshots are merged back into the origin volumes).

Clean up

Delete snapshot set when no longer needed:

snapm snapset delete before-upgrade

Common Workflows

System Updates

Before major system updates:

snapm snapset create --bootable --revert pre-update / /var

If update goes wrong, revert:

snapm snapset revert pre-update

When satisfied with update, clean up:

snapm snapset delete pre-update

Development Snapshots

Quick development checkpoint:

snapm snapset create dev-checkpoint /home /var

Continue working...

If needed, revert specific volumes by splitting them into a dedicated snapshot set first:

snapm snapset split dev-checkpoint dev-checkpoint-home /home

Example output:

SnapsetName:      dev-checkpoint-home
Sources:          /home
NrSnapshots:      1
Time:             2025-08-30 12:44:00
UUID:             ee82269f-8c78-5814-b47a-b9be31bcebb5
Status:           Inactive
Autoactivate:     no
Bootable:         no
snapm snapset revert dev-checkpoint-home

Alternatively revert the entire snapshot set:

snapm snapset revert dev-checkpoint

Documentation

Requirements

  • Linux system with LVM2 or Stratis volumes
  • boom-boot
  • Root privileges for performing storage operations
  • Python 3.9+

Supported Storage Backends

Backend Type Snapshots Thin Provisioning Status
LVM2 Copy-on-Write Stable
LVM2 Thin Thin Pools Stable
Stratis Thin Pools Stable

Contributing

We welcome contributions! Please see CONTRIBUTING.md for guidelines.

Support

License

Licensed under the Apache License, Version 2.0. See LICENSE for details.

Related Projects

  • boom - Boot manager for Linux snapshot boot
  • stratis-cli - Command-line tool for Stratis storage
  • lvm2 - The LVM2 logical volume manager

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

snapm-0.6.0.tar.gz (200.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

snapm-0.6.0-py3-none-any.whl (179.8 kB view details)

Uploaded Python 3

File details

Details for the file snapm-0.6.0.tar.gz.

File metadata

  • Download URL: snapm-0.6.0.tar.gz
  • Upload date:
  • Size: 200.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.9

File hashes

Hashes for snapm-0.6.0.tar.gz
Algorithm Hash digest
SHA256 18e1cbc900d736755dffce09986179e0f3e847ab3d86a0647a1fccd9f5b31252
MD5 66dbc62cd31fa35bbf302edfe5775112
BLAKE2b-256 0f29aef5b87355f69ba7381a107dcb57f3af21696ee9604620e42368a041fdf5

See more details on using hashes here.

File details

Details for the file snapm-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: snapm-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 179.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.9

File hashes

Hashes for snapm-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86fcba78f72570b99e83d5b492c34da4d45f31649d145431c71344703b0b9ce0
MD5 7d9b321a70af932acc571342eb8c3f38
BLAKE2b-256 cd594d48b7661201f167eab3e44e46732aa2fb6b582d3b2cb323da97761402ce

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page