Skip to main content

Vollverschlüsselte, pseudoinkrementelle Sicherungskopien leicht gemacht

Project description

Code style: black Imports: isort Checked with mypy License: GPL v3

ButterBackup-Logo

ButterBackup - Backups so geschmeidig wie Butter!

Inkrementelle Vollbackups dank BtrFS

Installation

ButterBackup kann direkt von PyPI installiert werden:

pipx install butter-backup

Es ist aber auch möglich, das Projekt kann aus dem lokalen Quellcode zu installieren:

uv build
pipx install dist/butter-backup-<version>.whl

Benutzung

asciicast

Verfügbare Module zum Anlegen von Sicherungskopien

Momentan stehen zwei Module zum Anlegen von Sicherungskopien zur Verfügung. Weitere Module sind momentan nicht geplant, aber prinzipiell möglich. Anfragen dazu sind sehr willkommen!

BtrFSRsync

Dieses Modul eignet sich besonders für Nutzer, die ihre Sicherungskopien einfach im Dateimanager durchsuchen möchten. Es kombiniert die Vorteile von BtrFS-Snapshots mit der Effizienz von rsync. Jeder Sicherungsvorgang legt ein neues BtrFS-Subvolume an, indem ein Snapshot des jüngsten Subvolumes erstellt wird. Dann wird mit rsync eine inkrementelle Kopie der Quelldateien in das neue Subvolume angelegt. Dies hat den Vorteil, dass die Sicherungskopie sehr schnell angelegt werden kann, da nur die geänderten Dateien kopiert werden müssen. Gleichzeitig sind die Sicherungskopien sehr platzsparend, da nur die geänderten Blöcke zusätzlich Speicherplatz benötigen.

Am Ende verhält sich jede Sicherungskopie wie eine Vollsicherung, da jedes Subvolume alle Dateien enthält. Gleichzeitig wird aber nur der Speicherplatz von inkrementellen Sicherungen benötigt.

Die Sicherungskopien können sehr einfach durchsucht werden, da jedes Subvolume als normales Verzeichnis erscheint. Nach butter-backup open sind alle Sicherungskopien direkt im Dateimanager verfügbar.

Achtung: Durch die konkrete Art der Verwendung von rsync werden Dateien, die denselben Namen, dieselbe Größe und denselben Zeitstempel haben, nicht kopiert. Sollte also z.B. ein Prozess auf einem Dateisystem ohne Änderungszeitstempel wiederholt Dateien überschreiben, ohne deren Größe zu ändern, so werden diese Dateien in der Sicherungskopie nicht aktualisiert.

Restic

Dieses Modul verwendet restic, um Sicherungskopien anzulegen. Das Programm restic ist ein sehr ausgereiftes Programm zum Anlegen von verschlüsselten Sicherungskopien mit fortgeschrittener Deduplizierung. Mehr Informationen zu restic und seinen Fähigkeiten finden sich auf der offiziellen Webseite. Für technisch versierte Nutzer wird dieses Modul empfohlen.

Hier steht nach butter-backup open nur ein einzelnes Verzeichnis zur Verfügung, in dem alle Sicherungskopien von restic enthalten sind. Der Zugriff auf einzelne Sicherungskopien erfolgt über die restic-Kommandozeile.

Gefährdungsszenario

ButterBackup wurde entworfen, um gegen eine Reihe spezieller Gefährdungsszenarien zu schützen. Die konkreten Bedrohungen und die entsprechenden Gegenmaßnahmen gibt die folgende Tabelle an. Auf die Übersichtstabelle folgt eine etwas ausführlichere Diskussion der Maßnahmen.

Bedrohung Gegenmaßnahme
Dateien verschlüsselnde Schadsoftware physikalisch getrennte Aufbewahrung
fehlerhafte Sicherungskopien durch Fehlbenutzung sehr einfache Benutzung
Verlust des Datenträgers Vollverschlüsselung des Datenträgers
Zerstörung des Datenträgers durch Spannungsspitzen physikalisch getrennte Aufbewahrung
zu seltene Sicherungskopien sehr einfache Benutzung

Diese Bedrohungen werden dadurch reduziert, dass eine sehr einfache Benutzung die physikalisch getrennte Aufbewahrung des die Sicherungskopien enthaltenen Datenträgers ermöglicht.

Eine einfach umzusetzende und verlässliche Maßnahme, um den Datenträger vor Zerstörung durch Spannungsspitzen zu schützen, ist, ihn vom Computer physikalisch getrennt aufzubewahren. Gleichzeitig schützt diese Maßnahme auch sehr gut vor der Zerstörung der Sicherungskopien durch Schadsoftware, da sich die Sicherungskopien außerhalb des Zugriffs der Schadsoftware befinden.

Durch die physikalisch getrennte Aufbewahrung ergibt sich aber eine Bedrohung durch Bequemlichkeit. Ein Prozess, für dessen Durchführung manuelle Schritte nötig sind, ist fehleranfällig und läuft Gefahr, im Zweifel nicht ausgeführt zu werden. Das Anlegen von Sicherungskopien stellt hier keine Ausnahme dar.

ButterBackup begegnet dieser Gefahr dadurch, dass es das Anlegen einer Sicherungskopie auf zwei manuelle Schritte reduziert. Es genügt, die Festplatte mit dem Computer zu verbinden und das Programm zu starten. Alle weiteren Schritte, z.B. Entschlüsselung, Kopie der Daten und Unmounten, werden von ButterBackup übernommen.

Insgesamt ermöglicht ButterBackup, Sicherungskopien so sicher wie möglich aufzubewahren ohne dabei zu verkomplizieren, neue Sicherungskopien anzulegen.

Ausführung der Tests

ButterBackup hat eine umfangreiche Testsuite, die viele relevanten Aspekte des Programms abdeckt. Diese wird ergänzt durch die ähnlich umfangreichen Testsuites der Abhängigkeiten storage-device-managers und shell-interface. Diese beiden Abhängigkeiten sind aus ButterBackup hervorgegangen, womit deren Testsuite weitere für ButterBackup wichtige Aspekte gründlich abdeckt.

Für die schnelle Ausführung während der Entwicklung bietet es sich an, die Testsuite direkt auszuführen. Dies ist wird im Abschnitt "schnell" erläutert. Spätestens vor einem Release sollten aber auch die distributionsübergreifenden Tests ausgeführt werden, da diese garantieren, dass ButterBackup auch unter Arch und allen unterstützten Pythonversionen funktioniert.

Schnell

Direkt

uv run ruff check .
uv run mypy .
uv run pytest

Mittels Makefile

make check-format check-linters run-undockered-tests

Plattformübergreifende Tests

Es existiert eine umfassende Testsuite, die auch gewisse Plattformabhängigkeiten erkennen kann. Die Docker-Tests existieren überhaupt nur, weil es Probleme mit Arch gab.

Die Testsuite kann mittels make ausgeführt werden. Es ist auch eine Parallelisierung mittels make -j N möglich, wobei N die Anzahl der Prozesse angibt.

Diese Tests werden ergänzt durch eine Testmatrix auf Github. Diese Testmatrix deckt Ubuntu mit allen unterstützten Pythonversionen ab. Dies erlaubt ggf., die sehr lang laufende Docker-Testsuite seltener auszuführen.

Designentscheidungen

Beibehaltung von nicht mehr vermerkten Zielordnern und -dateien

In den Konfigurationen müssen Zielordner und Dateien angegeben werden. Nun ist es denkbar, dass einige dieser Ziele umbenannt oder entfernt werden. Als Beispiel diene hier das Backup des Ordners Videos-Quelle nach Videos-Ziel. Ein Nutzer könnte sich nun entscheiden, aus Platzgründen Videos-Quelle auf eine externe Festplatte auszulagern. Die Backup-Anweisung könnte damit entfernt werden.

In diesem Fall wird ButterBackup Videos-Ziel nicht löschen. Der offensichtlichste Grund ist, dass dies das Programm verkomplizieren würde. Es ist ohne weiteres möglich, über butter-backup open die Sicherungskopien zu öffnen und nicht mehr benötigte Ordner händisch zu löschen.

Außerdem ist es vorstellbar, dass die Quelle zwar gelöscht wurde, aber im Backup archiviert werden soll. Dieser Anwendungsfall würde unmöglich gemacht, würden nicht mehr gelistete Ziele aus der Sicherungskopie entfernt.

Ausstehende Aufgaben

  • README schreiben und übersetzen
  • Testsuite umstellen von Docker auf virtuelle Maschinen
  • Alias für Einzelkonfigurationen?
  • butter-backup exec / run
    • nimmt Befehl als Zeichenkette und führt diesen im BackupRootDir aus
    • butter-backup exec [] --> open; cd; cmd; cd -; close
    • sollte Mapping auf Umgebungsvariablen unterstützen, z.B. RepoPassCmd -> RESTIC_PASSWORD_COMMAND
  • Verbesserte Fehlermeldungen
    • wenn unmount nicht möglich ist
    • wenn BackupRepository nicht vorhanden ist
  • SudoPassCmd
  • Konfiguration der gewünschten Kompression ermöglichen (zlib, zstd, none, etc.)

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

butter_backup-3.6.0.tar.gz (27.1 kB view details)

Uploaded Source

Built Distribution

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

butter_backup-3.6.0-py3-none-any.whl (25.8 kB view details)

Uploaded Python 3

File details

Details for the file butter_backup-3.6.0.tar.gz.

File metadata

  • Download URL: butter_backup-3.6.0.tar.gz
  • Upload date:
  • Size: 27.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for butter_backup-3.6.0.tar.gz
Algorithm Hash digest
SHA256 906196042faf607ae6ea1b867b6775da0564783e2e116f7038a47c2a77d14d58
MD5 06dc240fb755042fa72c78b9cf211298
BLAKE2b-256 e69320d9235e52559e42d461a673088f72507956e7f9ffd3c3194898bd6e0524

See more details on using hashes here.

Provenance

The following attestation bundles were made for butter_backup-3.6.0.tar.gz:

Publisher: python-publish.yml on MaxG87/ButterBackup

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file butter_backup-3.6.0-py3-none-any.whl.

File metadata

  • Download URL: butter_backup-3.6.0-py3-none-any.whl
  • Upload date:
  • Size: 25.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for butter_backup-3.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 52d86fc4db3b8c1f80dbb2a25dd1014b8be0de5b2d2aeeb8f451f4dfdace1572
MD5 c639c5c78079c2d2ccfcf365b3748fda
BLAKE2b-256 090c58cf5363b2e54a6469d356f4987e3db1af9bfb9926f2112689a7c87f092d

See more details on using hashes here.

Provenance

The following attestation bundles were made for butter_backup-3.6.0-py3-none-any.whl:

Publisher: python-publish.yml on MaxG87/ButterBackup

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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