Skip to main content

MCP server for managing BTRFS snapshots via Snapper

Project description

BTRFS Snapper MCP

PyPI Built with Claude Code

An MCP (Model Context Protocol) server for managing BTRFS snapshots via Snapper and monitoring BTRFS filesystem health. Exposes two unified tools with action-based dispatch to minimize tool proliferation while providing full snapshot management and disk health monitoring.

Features

  • Two-tool design: snapper for snapshots, btrfs_health for filesystem monitoring
  • Full Snapper support: list, create, delete, rollback, cleanup, diff, status
  • BTRFS health monitoring: usage, device stats, scrub status, balance status
  • Flexible configuration: Environment variables for cross-system portability
  • No hardcoded paths: Works with any Snapper configuration and mount points

Installation

From PyPI (recommended)

pip install snapper-mcp

Using uvx (no install required)

uvx snapper-mcp

From source

git clone https://github.com/danielrosehill/BTRFS-Snapper-MCP.git
cd BTRFS-Snapper-MCP
pip install -e .

Configuration

The server is configured via environment variables, making it portable across systems:

Variable Default Description
SNAPPER_MCP_USE_SUDO true Set to false if user has direct permissions
SNAPPER_MCP_SNAPPER_PATH snapper Path to snapper binary
SNAPPER_MCP_BTRFS_PATH btrfs Path to btrfs binary
SNAPPER_MCP_SUDO_PATH sudo Path to sudo binary
SNAPPER_MCP_DEFAULT_CONFIG root Default snapper config name
SNAPPER_MCP_DEFAULT_MOUNT / Default BTRFS mount point
SNAPPER_MCP_TIMEOUT 60 Command timeout in seconds

MCP Client Configuration

Claude Code / Claude Desktop

Add to your MCP settings (e.g., ~/.claude/settings.json or Claude Desktop config):

{
  "mcpServers": {
    "btrfs-snapper": {
      "command": "uvx",
      "args": ["snapper-mcp"]
    }
  }
}

With custom configuration

{
  "mcpServers": {
    "btrfs-snapper": {
      "command": "uvx",
      "args": ["snapper-mcp"],
      "env": {
        "SNAPPER_MCP_DEFAULT_CONFIG": "root",
        "SNAPPER_MCP_DEFAULT_MOUNT": "/",
        "SNAPPER_MCP_USE_SUDO": "true"
      }
    }
  }
}

Tools

snapper - Snapshot Management

Manages BTRFS snapshots via Snapper.

Actions

Action Description Required Parameters
configs List available snapper configurations -
list Show all snapshots for a config config (optional)
create Create a new snapshot config, description (optional)
delete Remove a snapshot by number config, snapshot_id
rollback Restore to a previous snapshot config, snapshot_id
cleanup Prune snapshots using an algorithm config, cleanup_algorithm
diff Show file differences between snapshots config, snapshot_id, snapshot_id_end
status List changed files between snapshots config, snapshot_id, snapshot_id_end

Examples

// List configurations
{"action": "configs"}

// List snapshots
{"action": "list", "config": "root"}

// Create snapshot
{"action": "create", "config": "root", "description": "Before system update"}

// Delete snapshot
{"action": "delete", "config": "root", "snapshot_id": 5}

// Rollback (requires reboot)
{"action": "rollback", "config": "root", "snapshot_id": 3}

// Cleanup with algorithm
{"action": "cleanup", "config": "root", "cleanup_algorithm": "number"}

// Compare snapshots
{"action": "diff", "config": "root", "snapshot_id": 1, "snapshot_id_end": 5}

Cleanup algorithms:

  • number: Keep a fixed number of snapshots
  • timeline: Keep snapshots based on age (hourly, daily, weekly, monthly, yearly)
  • empty-pre-post: Remove empty pre/post snapshot pairs

btrfs_health - Filesystem Health Monitoring

Monitors BTRFS filesystem health and status.

Actions

Action Description Parameters
usage Comprehensive filesystem space usage mount_point (optional)
devices List devices in the BTRFS array mount_point (optional)
stats Device error statistics mount_point, device (optional)
scrub_status Status of scrub operation mount_point (optional)
balance_status Status of balance operation mount_point (optional)
df Space allocation by data type mount_point (optional)
filesystem_show Filesystem information mount_point (optional)

Examples

// Check filesystem usage
{"action": "usage", "mount_point": "/"}

// Check for device errors
{"action": "stats", "mount_point": "/"}

// Check scrub status
{"action": "scrub_status", "mount_point": "/"}

// Show data/metadata allocation
{"action": "df", "mount_point": "/"}

// Show filesystem info
{"action": "filesystem_show"}

Prerequisites

  • Linux with BTRFS filesystem
  • Snapper installed and configured (for snapshot management)
  • Python 3.10+
  • Sudo access (unless running as root or with appropriate permissions)

Installing Snapper

Ubuntu/Debian:

sudo apt install snapper

Fedora/openSUSE:

sudo dnf install snapper
# or
sudo zypper install snapper

Creating Snapper Configs

# For root filesystem
sudo snapper -c root create-config /

# For home partition
sudo snapper -c home create-config /home

Sudo Configuration

For passwordless operation, add to /etc/sudoers.d/btrfs-snapper:

yourusername ALL=(ALL) NOPASSWD: /usr/bin/snapper
yourusername ALL=(ALL) NOPASSWD: /usr/bin/btrfs

Or disable sudo if you have direct permissions:

{
  "env": {
    "SNAPPER_MCP_USE_SUDO": "false"
  }
}

Adapting for Other Systems

Different Snapshot Tools

The architecture can be adapted for other snapshot tools (e.g., Timeshift, ZFS snapshots) by:

  1. Replacing the run_snapper_command() function with your tool's CLI
  2. Adjusting the action handlers for your tool's command syntax
  3. Updating environment variables as needed

Different Filesystems

For ZFS or other filesystems:

  1. Replace run_btrfs_command() with your filesystem's CLI
  2. Update BtrfsAction enum with relevant actions
  3. Implement new handlers for your filesystem's commands

The action-dispatch pattern remains the same regardless of underlying tools.

License

MIT

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

snapper_mcp-0.1.1.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

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

snapper_mcp-0.1.1-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file snapper_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: snapper_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for snapper_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 cf2b3fe6f7a9955c789fd6fa7e4e113de9dbf16225914af30504e027d7099b1a
MD5 421d77c782b98e394a867c1f015427ad
BLAKE2b-256 5333c15bc4855880e41c45be7f243023821dac20417f16f4bd73cfdbc513e216

See more details on using hashes here.

File details

Details for the file snapper_mcp-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: snapper_mcp-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for snapper_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 24b0bb855d72a291ad9fa4e0af93632f0005a92045c4de0702620ecb95d13490
MD5 a94811811e18ab6678785a76ca6834e2
BLAKE2b-256 d610f96da61cc5c8150b90e28c85da3ddf269f29ec2d2825d8fc8d96987a2102

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