2015-10-24 21:58:05 +00:00
|
|
|
|screencast|
|
|
|
|
|
|
|
|
.. |screencast| image:: https://asciinema.org/a/28691.png
|
|
|
|
:alt: BorgBackup Installation and Basic Usage
|
|
|
|
:target: https://asciinema.org/a/28691?autoplay=1&speed=2
|
|
|
|
|
|
|
|
|
2015-08-06 14:39:50 +00:00
|
|
|
What is BorgBackup?
|
2015-10-13 03:36:31 +00:00
|
|
|
===================
|
2015-08-06 14:39:50 +00:00
|
|
|
BorgBackup (short: Borg) is a deduplicating backup program.
|
|
|
|
Optionally, it supports compression and authenticated encryption.
|
2015-05-13 22:37:09 +00:00
|
|
|
|
2015-08-06 10:59:51 +00:00
|
|
|
The main goal of Borg is to provide an efficient and secure way to backup data.
|
|
|
|
The data deduplication technique used makes Borg suitable for daily backups
|
|
|
|
since only changes are stored.
|
|
|
|
The authenticated encryption technique makes it suitable for backups to not
|
|
|
|
fully trusted targets.
|
2015-07-27 12:45:32 +00:00
|
|
|
|
2015-10-07 22:33:43 +00:00
|
|
|
See the `installation manual`_ or, if you have already
|
2015-10-07 21:36:34 +00:00
|
|
|
downloaded Borg, ``docs/installation.rst`` to get started with Borg.
|
2015-08-06 14:39:50 +00:00
|
|
|
|
2015-11-15 00:13:25 +00:00
|
|
|
.. _installation manual: https://borgbackup.readthedocs.org/en/stable/installation.html
|
2015-08-06 14:39:50 +00:00
|
|
|
|
2013-07-03 20:38:17 +00:00
|
|
|
Main features
|
2015-10-13 03:36:31 +00:00
|
|
|
-------------
|
2015-08-06 14:39:50 +00:00
|
|
|
**Space efficient storage**
|
|
|
|
Deduplication based on content-defined chunking is used to reduce the number
|
|
|
|
of bytes stored: each file is split into a number of variable length chunks
|
|
|
|
and only chunks that have never been seen before are added to the repository.
|
|
|
|
|
|
|
|
To deduplicate, all the chunks in the same repository are considered, no
|
|
|
|
matter whether they come from different machines, from previous backups,
|
|
|
|
from the same backup or even from the same single file.
|
|
|
|
|
|
|
|
Compared to other deduplication approaches, this method does NOT depend on:
|
|
|
|
|
|
|
|
* file/directory names staying the same
|
|
|
|
|
|
|
|
So you can move your stuff around without killing the deduplication,
|
|
|
|
even between machines sharing a repo.
|
|
|
|
|
|
|
|
* complete files or time stamps staying the same
|
|
|
|
|
|
|
|
If a big file changes a little, only a few new chunks will be stored -
|
|
|
|
this is great for VMs or raw disks.
|
|
|
|
|
|
|
|
* the absolute position of a data chunk inside a file
|
|
|
|
|
|
|
|
Stuff may get shifted and will still be found by the deduplication
|
|
|
|
algorithm.
|
|
|
|
|
|
|
|
**Speed**
|
|
|
|
* performance critical code (chunking, compression, encryption) is
|
|
|
|
implemented in C/Cython
|
|
|
|
* local caching of files/chunks index data
|
|
|
|
* quick detection of unmodified files
|
|
|
|
|
|
|
|
**Data encryption**
|
|
|
|
All data can be protected using 256-bit AES encryption, data integrity and
|
2015-12-03 16:35:52 +00:00
|
|
|
authenticity is verified using HMAC-SHA256. Data is encrypted clientside.
|
2015-08-06 14:39:50 +00:00
|
|
|
|
|
|
|
**Compression**
|
2015-08-15 13:45:15 +00:00
|
|
|
All data can be compressed by lz4 (super fast, low compression), zlib
|
|
|
|
(medium speed and compression) or lzma (low speed, high compression).
|
2015-08-06 14:39:50 +00:00
|
|
|
|
|
|
|
**Off-site backups**
|
|
|
|
Borg can store data on any remote host accessible over SSH. If Borg is
|
|
|
|
installed on the remote host, big performance gains can be achieved
|
|
|
|
compared to using a network filesystem (sshfs, nfs, ...).
|
|
|
|
|
|
|
|
**Backups mountable as filesystems**
|
|
|
|
Backup archives are mountable as userspace filesystems for easy interactive
|
|
|
|
backup examination and restores (e.g. by using a regular file manager).
|
|
|
|
|
2015-10-07 22:15:30 +00:00
|
|
|
**Easy installation on multiple platforms**
|
2015-10-07 22:37:35 +00:00
|
|
|
We offer single-file binaries
|
2015-10-07 22:15:30 +00:00
|
|
|
that does not require installing anything - you can just run it on
|
|
|
|
the supported platforms:
|
|
|
|
|
|
|
|
* Linux
|
|
|
|
* Mac OS X
|
|
|
|
* FreeBSD
|
2015-10-07 22:37:35 +00:00
|
|
|
* OpenBSD and NetBSD (no xattrs/ACLs support or binaries yet)
|
|
|
|
* Cygwin (not supported, no binaries yet)
|
2015-08-06 10:59:51 +00:00
|
|
|
|
2015-08-06 14:39:50 +00:00
|
|
|
**Free and Open Source Software**
|
|
|
|
* security and functionality can be audited independently
|
|
|
|
* licensed under the BSD (3-clause) license
|
|
|
|
|
2015-08-06 10:59:51 +00:00
|
|
|
|
|
|
|
Easy to use
|
2015-10-13 03:36:31 +00:00
|
|
|
-----------
|
2015-08-06 10:59:51 +00:00
|
|
|
Initialize a new backup repository and create a backup archive::
|
|
|
|
|
|
|
|
$ borg init /mnt/backup
|
|
|
|
$ borg create /mnt/backup::Monday ~/Documents
|
|
|
|
|
|
|
|
Now doing another backup, just to show off the great deduplication::
|
|
|
|
|
2015-10-15 23:18:37 +00:00
|
|
|
$ borg create --stats -C zlib,6 /mnt/backup::Tuesday ~/Documents
|
2015-08-06 10:59:51 +00:00
|
|
|
|
|
|
|
Archive name: Tuesday
|
2015-08-06 14:39:50 +00:00
|
|
|
Archive fingerprint: 387a5e3f9b0e792e91c...
|
2015-08-06 10:59:51 +00:00
|
|
|
Start time: Tue Mar 25 12:00:10 2014
|
|
|
|
End time: Tue Mar 25 12:00:10 2014
|
|
|
|
Duration: 0.08 seconds
|
|
|
|
Number of files: 358
|
2015-08-06 14:39:50 +00:00
|
|
|
Original size Compressed size Deduplicated size
|
|
|
|
This archive: 57.16 MB 46.78 MB 151.67 kB <--- !
|
|
|
|
All archives: 114.02 MB 93.46 MB 44.81 MB
|
2015-08-06 10:59:51 +00:00
|
|
|
|
2015-12-03 16:13:39 +00:00
|
|
|
For a graphical frontend refer to our complementary project `BorgWeb <https://borgbackup.github.io/borgweb/>`_.
|
2015-08-06 10:59:51 +00:00
|
|
|
|
2015-10-13 03:27:59 +00:00
|
|
|
Links
|
2015-10-13 03:36:31 +00:00
|
|
|
=====
|
2015-10-13 03:27:59 +00:00
|
|
|
|
|
|
|
* `Main Web Site <https://borgbackup.readthedocs.org/>`_
|
|
|
|
* `Releases <https://github.com/borgbackup/borg/releases>`_
|
|
|
|
* `PyPI packages <https://pypi.python.org/pypi/borgbackup>`_
|
|
|
|
* `ChangeLog <https://github.com/borgbackup/borg/blob/master/CHANGES.rst>`_
|
|
|
|
* `GitHub <https://github.com/borgbackup/borg>`_
|
|
|
|
* `Issue Tracker <https://github.com/borgbackup/borg/issues>`_
|
|
|
|
* `Bounties & Fundraisers <https://www.bountysource.com/teams/borgbackup>`_
|
2015-11-18 14:40:23 +00:00
|
|
|
* `New Mailing List <https://mail.python.org/mailman/listinfo/borgbackup>`_
|
|
|
|
* `(Old Mailing List's Archives <http://librelist.com/browser/borgbackup/>`_)
|
2015-10-13 03:27:59 +00:00
|
|
|
* `License <https://borgbackup.github.io/borgbackup/authors.html#license>`_
|
|
|
|
|
2015-08-06 10:59:51 +00:00
|
|
|
Notes
|
|
|
|
-----
|
|
|
|
|
2015-10-13 03:27:59 +00:00
|
|
|
Borg is a fork of `Attic`_ and maintained by "`The Borg collective`_".
|
2015-10-07 22:33:43 +00:00
|
|
|
|
2015-12-03 16:13:39 +00:00
|
|
|
.. _Attic: https://github.com/jborg/attic
|
2015-11-06 15:22:05 +00:00
|
|
|
.. _The Borg collective: https://borgbackup.readthedocs.org/en/latest/authors.html
|
2015-08-06 10:59:51 +00:00
|
|
|
|
2015-10-17 20:27:59 +00:00
|
|
|
Differences between Attic and Borg
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Here's a (incomplete) list of some major changes:
|
|
|
|
|
|
|
|
* more open, faster paced development (see `issue #1 <https://github.com/borgbackup/borg/issues/1>`_)
|
|
|
|
* lots of attic issues fixed (see `issue #5 <https://github.com/borgbackup/borg/issues/5>`_)
|
|
|
|
* less chunk management overhead via --chunker-params option (less memory and disk usage)
|
|
|
|
* faster remote cache resync (useful when backing up multiple machines into same repo)
|
|
|
|
* compression: no, lz4, zlib or lzma compression, adjustable compression levels
|
|
|
|
* repokey replaces problematic passphrase mode (you can't change the passphrase nor the pbkdf2 iteration count in "passphrase" mode)
|
|
|
|
* simple sparse file support, great for virtual machine disk files
|
|
|
|
* can read special files (e.g. block devices) or from stdin, write to stdout
|
|
|
|
* mkdir-based locking is more compatible than attic's posix locking
|
|
|
|
* uses fadvise to not spoil / blow up the fs cache
|
|
|
|
* better error messages / exception handling
|
|
|
|
* better output for verbose mode, progress indication
|
|
|
|
* tested on misc. Linux systems, 32 and 64bit, FreeBSD, OpenBSD, NetBSD, Mac OS X
|
|
|
|
|
|
|
|
Please read the `ChangeLog`_ (or ``CHANGES.rst`` in the source distribution) for more
|
|
|
|
information.
|
|
|
|
|
|
|
|
BORG IS NOT COMPATIBLE WITH ORIGINAL ATTIC (but there is a one-way conversion).
|
2015-08-06 14:39:50 +00:00
|
|
|
|
2015-08-06 10:59:51 +00:00
|
|
|
EXPECT THAT WE WILL BREAK COMPATIBILITY REPEATEDLY WHEN MAJOR RELEASE NUMBER
|
2015-10-17 20:27:59 +00:00
|
|
|
CHANGES (like when going from 0.x.y to 1.0.0).
|
2015-10-07 22:33:43 +00:00
|
|
|
|
2015-08-06 10:59:51 +00:00
|
|
|
NOT RELEASED DEVELOPMENT VERSIONS HAVE UNKNOWN COMPATIBILITY PROPERTIES.
|
|
|
|
|
|
|
|
THIS IS SOFTWARE IN DEVELOPMENT, DECIDE YOURSELF WHETHER IT FITS YOUR NEEDS.
|
2010-10-27 18:40:48 +00:00
|
|
|
|
2015-10-13 03:27:59 +00:00
|
|
|
Borg is distributed under a 3-clause BSD license, see `License`_
|
2015-10-07 22:33:43 +00:00
|
|
|
for the complete license.
|
|
|
|
|
2015-08-08 00:34:42 +00:00
|
|
|
|build| |coverage|
|
2015-05-09 16:40:55 +00:00
|
|
|
|
|
|
|
.. |build| image:: https://travis-ci.org/borgbackup/borg.svg
|
|
|
|
:alt: Build Status
|
|
|
|
:target: https://travis-ci.org/borgbackup/borg
|
2015-08-08 00:34:42 +00:00
|
|
|
|
2015-12-07 02:08:32 +00:00
|
|
|
.. |coverage| image:: https://codecov.io/github/borgbackup/borg/coverage.svg?branch=master
|
2015-08-08 00:34:42 +00:00
|
|
|
:alt: Test Coverage
|
2015-12-07 02:08:32 +00:00
|
|
|
:target: https://codecov.io/github/borgbackup/borg?branch=master
|