2016-07-05 21:30:08 +00:00
|
|
|
.. IMPORTANT: this file is auto-generated from borg's built-in help, do not edit!
|
|
|
|
|
2015-11-13 15:42:16 +00:00
|
|
|
.. _borg_check:
|
|
|
|
|
|
|
|
borg check
|
|
|
|
----------
|
|
|
|
::
|
|
|
|
|
2016-04-09 23:28:18 +00:00
|
|
|
borg check <options> REPOSITORY_OR_ARCHIVE
|
|
|
|
|
|
|
|
positional arguments
|
|
|
|
REPOSITORY_OR_ARCHIVE
|
|
|
|
repository or archive to check consistency of
|
|
|
|
|
|
|
|
optional arguments
|
|
|
|
``--repository-only``
|
|
|
|
| only perform repository checks
|
|
|
|
``--archives-only``
|
|
|
|
| only perform archives checks
|
2016-07-05 23:33:53 +00:00
|
|
|
``--verify-data``
|
|
|
|
| perform cryptographic archive data integrity verification (conflicts with --repository-only)
|
2016-04-09 23:28:18 +00:00
|
|
|
``--repair``
|
|
|
|
| attempt to repair any inconsistencies found
|
|
|
|
``--save-space``
|
|
|
|
| work slower, but using less space
|
2016-07-05 23:33:53 +00:00
|
|
|
``-p``, ``--progress``
|
|
|
|
| show progress display while checking
|
2016-04-09 23:28:18 +00:00
|
|
|
|
|
|
|
`Common options`_
|
|
|
|
|
|
|
|
|
|
2016-11-28 01:25:56 +00:00
|
|
|
filters
|
|
|
|
``-P``, ``--prefix``
|
|
|
|
| only consider archive names starting with this prefix
|
|
|
|
``--sort-by``
|
|
|
|
| Comma-separated list of sorting keys; valid keys are: timestamp, name, id; default is: timestamp
|
|
|
|
``--first N``
|
|
|
|
| consider first N archives after other filters were applied
|
|
|
|
``--last N``
|
|
|
|
| consider last N archives after other filters were applied
|
|
|
|
|
2015-11-13 15:42:16 +00:00
|
|
|
Description
|
|
|
|
~~~~~~~~~~~
|
|
|
|
|
|
|
|
The check command verifies the consistency of a repository and the corresponding archives.
|
|
|
|
|
|
|
|
First, the underlying repository data files are checked:
|
|
|
|
|
|
|
|
- For all segments the segment magic (header) is checked
|
|
|
|
- For all objects stored in the segments, all metadata (e.g. crc and size) and
|
|
|
|
all data is read. The read data is checked by size and CRC. Bit rot and other
|
|
|
|
types of accidental damage can be detected this way.
|
|
|
|
- If we are in repair mode and a integrity error is detected for a segment,
|
|
|
|
we try to recover as many objects from the segment as possible.
|
|
|
|
- In repair mode, it makes sure that the index is consistent with the data
|
|
|
|
stored in the segments.
|
|
|
|
- If you use a remote repo server via ssh:, the repo check is executed on the
|
|
|
|
repo server without causing significant network traffic.
|
|
|
|
- The repository check can be skipped using the --archives-only option.
|
|
|
|
|
|
|
|
Second, the consistency and correctness of the archive metadata is verified:
|
|
|
|
|
|
|
|
- Is the repo manifest present? If not, it is rebuilt from archive metadata
|
|
|
|
chunks (this requires reading and decrypting of all metadata and data).
|
|
|
|
- Check if archive metadata chunk is present. if not, remove archive from
|
|
|
|
manifest.
|
|
|
|
- For all files (items) in the archive, for all chunks referenced by these
|
2016-07-10 17:00:55 +00:00
|
|
|
files, check if chunk is present.
|
|
|
|
If a chunk is not present and we are in repair mode, replace it with a same-size
|
|
|
|
replacement chunk of zeros.
|
|
|
|
If a previously lost chunk reappears (e.g. via a later backup) and we are in
|
|
|
|
repair mode, the all-zero replacement chunk will be replaced by the correct chunk.
|
|
|
|
This requires reading of archive and file metadata, but not data.
|
2015-11-13 15:42:16 +00:00
|
|
|
- If we are in repair mode and we checked all the archives: delete orphaned
|
|
|
|
chunks from the repo.
|
|
|
|
- if you use a remote repo server via ssh:, the archive check is executed on
|
|
|
|
the client machine (because if encryption is enabled, the checks will require
|
|
|
|
decryption and this is always done client-side, because key access will be
|
|
|
|
required).
|
|
|
|
- The archive checks can be time consuming, they can be skipped using the
|
|
|
|
--repository-only option.
|
2016-07-05 23:33:53 +00:00
|
|
|
|
|
|
|
The --verify-data option will perform a full integrity verification (as opposed to
|
|
|
|
checking the CRC32 of the segment) of data, which means reading the data from the
|
|
|
|
repository, decrypting and decompressing it. This is a cryptographic verification,
|
|
|
|
which will detect (accidental) corruption. For encrypted repositories it is
|
|
|
|
tamper-resistant as well, unless the attacker has access to the keys.
|
|
|
|
|
|
|
|
It is also very slow.
|