* Komprimierung: LZ4, zlib, LZMA, zstd (seit borg 1.1.4)
* Einbindbare Sicherungen mit FUSE
* Einfache Installation auf mehreren Plattformen: Linux, macOS, BSD...
* Freie Software (BSD-Lizenz)
* Unterstützt von einer großen und aktiven Open-Source-Gemeinschaft
===== Pakete =====
<code>
pacman -S borg python-llfuse
</code>
<alert type="info" icon="fa fa-info-circle">Das ''borg'' Paket muss auf dem Backup-Server und dem Client installiert sein. ''python-llfuse'' dient zum Einbinden eines Backups.</alert>
<alert type="danger" icon="fa fa-warning">Both [[https://github.com/python-llfuse/python-llfuse/#the-python-llfuse-module=|llfuse]] als auch [[https://github.com/libfuse/pyfuse3|pyfuse3]] werden nicht mehr gepflegt - Stand 29.05.2022.</alert>
===== Backup =====
Wenn du dies einfach nur erledigen willst, gehe zu unserem [[de:backup:server#borg|Backup-Bereich]], der das borg script enthält.
Unten findest du einige Kommandobeispiele/Informationen.
==== Repo erstellen ====
<code>
borg init --encryption=keyfile-blake2 --make-parent-dirs borg/
Der Schlüssel wird unter home dir gespeichert - ''~/.config/borg/keys/''.
<code>
borg init --encryption=keyfile user@hostname:backup
</code>
==== Remote / SSH mit Speicherplatzkontingent ====
<code>
borg init --encryption=keyfile-blake2 --storage-quota (e.g. 5G, 1.5T) --make-parent-dirs ssh://username@remote.host.address:$port/~/borg
</code>
==== Liste / Einhängen / Aushängen von Backups ====
<code>
borg list /path
</code>
<code>
mkdir /path/mount/
borg mount .::Tuesday /path/mount/
</code>
<code>
borg mount repo/ /path/mount/
</code>
<code>
borg umount .::Tuesday /path/mount/
borg umount repo/ /path/mount/
</code>
<alert type="info" icon="fa fa-info-circle">Der Pfad muss für borg beschreibbar sein! Ein im Home-Ordner erstellter Pfad bedeutet, dass der Mount-Ordner für den Home-Benutzer beschreibbar sein muss.</alert>
==== Unterschied zwischen zwei Backups ====
<code>
borg diff repo/::archive-2022-02-14T23:18:18 archive-2022-02-14T23:26:10
</code>
==== Delete ====
Wenn du ein Backup endgültig löschen willst, führe den Befehl ohne ''%%--%%dry-run'' aus.
<code>
borg delete --dry-run --stats repo/
borg delete --dry-run --stats repo/::archive-2022-02-14T23:26:10