2019-02-04 06:20:59 +00:00
|
|
|
---
|
|
|
|
title: How to deal with very large backups
|
2020-08-21 22:27:47 +01:00
|
|
|
eleventyNavigation:
|
2022-05-20 19:11:35 +01:00
|
|
|
key: 📏 Deal with very large backups
|
2020-08-21 22:27:47 +01:00
|
|
|
parent: How-to guides
|
|
|
|
order: 3
|
2019-02-04 06:20:59 +00:00
|
|
|
---
|
|
|
|
## Biggish data
|
|
|
|
|
|
|
|
Borg itself is great for efficiently de-duplicating data across successive
|
2019-02-05 04:58:27 +00:00
|
|
|
backup archives, even when dealing with very large repositories. But you may
|
2022-02-09 22:33:12 +00:00
|
|
|
find that while borgmatic's default mode of `prune`, `compact`, `create`, and
|
|
|
|
`check` works well on small repositories, it's not so great on larger ones.
|
|
|
|
That's because running the default pruning, compact, and consistency checks
|
|
|
|
take a long time on large repositories.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
### A la carte actions
|
|
|
|
|
|
|
|
If you find yourself in this situation, you have some options. First, you can
|
2022-02-09 22:33:12 +00:00
|
|
|
run borgmatic's `prune`, `compact`, `create`, or `check` actions separately.
|
|
|
|
For instance, the following optional actions are available:
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
```bash
|
2019-06-23 06:09:50 +01:00
|
|
|
borgmatic prune
|
2022-02-09 22:33:12 +00:00
|
|
|
borgmatic compact
|
2019-06-23 06:09:50 +01:00
|
|
|
borgmatic create
|
|
|
|
borgmatic check
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
2019-06-24 00:42:23 +01:00
|
|
|
(No borgmatic `prune`, `create`, or `check` actions? Try the old-style
|
|
|
|
`--prune`, `--create`, or `--check`. Or upgrade borgmatic!)
|
|
|
|
|
2019-10-11 18:46:30 +01:00
|
|
|
You can run with only one of these actions provided, or you can mix and match
|
2019-02-04 06:20:59 +00:00
|
|
|
any number of them in a single borgmatic run. This supports approaches like
|
2020-03-09 18:20:18 +00:00
|
|
|
skipping certain actions while running others. For instance, this skips
|
2022-02-09 22:33:12 +00:00
|
|
|
`prune` and `compact` and only runs `create` and `check`:
|
2020-03-09 18:20:18 +00:00
|
|
|
|
|
|
|
```bash
|
|
|
|
borgmatic create check
|
|
|
|
```
|
|
|
|
|
|
|
|
Or, you can make backups with `create` on a frequent schedule (e.g. with
|
|
|
|
`borgmatic create` called from one cron job), while only running expensive
|
|
|
|
consistency checks with `check` on a much less frequent basis (e.g. with
|
|
|
|
`borgmatic check` called from a separate cron job).
|
|
|
|
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
### Consistency check configuration
|
|
|
|
|
|
|
|
Another option is to customize your consistency checks. The default
|
|
|
|
consistency checks run both full-repository checks and per-archive checks
|
2022-05-28 23:49:50 +01:00
|
|
|
within each repository no more than once a month.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
2019-02-05 04:58:27 +00:00
|
|
|
But if you find that archive checks are too slow, for example, you can
|
2019-02-04 06:20:59 +00:00
|
|
|
configure borgmatic to run repository checks only. Configure this in the
|
|
|
|
`consistency` section of borgmatic configuration:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
consistency:
|
|
|
|
checks:
|
2022-05-28 22:42:19 +01:00
|
|
|
- name: repository
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
2022-05-29 03:03:45 +01:00
|
|
|
(Prior to borgmatic 1.6.2, `checks` was a plain list of strings without the `name:` part.)
|
|
|
|
|
2020-04-29 19:08:41 +01:00
|
|
|
Here are the available checks from fastest to slowest:
|
|
|
|
|
|
|
|
* `repository`: Checks the consistency of the repository itself.
|
|
|
|
* `archives`: Checks all of the archives in the repository.
|
|
|
|
* `extract`: Performs an extraction dry-run of the most recent archive.
|
|
|
|
* `data`: Verifies the data integrity of all archives contents, decrypting and decompressing all data (implies `archives` as well).
|
|
|
|
|
|
|
|
See [Borg's check documentation](https://borgbackup.readthedocs.io/en/stable/usage/check.html) for more information.
|
|
|
|
|
2022-05-28 22:42:19 +01:00
|
|
|
### Check frequency
|
|
|
|
|
2022-05-28 23:49:50 +01:00
|
|
|
As of borgmatic 1.6.2, you can optionally configure checks to run on a
|
|
|
|
periodic basis rather than every time borgmatic runs checks. For instance:
|
2022-05-28 22:42:19 +01:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
consistency:
|
|
|
|
checks:
|
|
|
|
- name: repository
|
|
|
|
frequency: 2 weeks
|
|
|
|
```
|
|
|
|
|
|
|
|
This tells borgmatic to run this consistency check at most once every two
|
|
|
|
weeks for a given repository. The `frequency` value is a number followed by a
|
|
|
|
unit of time, e.g. "3 days", "1 week", "2 months", etc. The `frequency`
|
|
|
|
defaults to "always", which means run this check every time checks run.
|
|
|
|
|
|
|
|
Unlike a real scheduler like cron, borgmatic only makes a best effort to run
|
|
|
|
checks on the configured frequency. It compares that frequency with how long
|
|
|
|
it's been since the last check for a given repository (as recorded in a file
|
|
|
|
within `~/.borgmatic/checks`). If it hasn't been long enough, the check is
|
|
|
|
skipped. And you still have to run `borgmatic check` (or just `borgmatic`) in
|
|
|
|
order for checks to run, even when a `frequency` is configured!
|
|
|
|
|
2022-05-29 03:29:33 +01:00
|
|
|
If you want to temporarily ignore your configured frequencies, you can invoke
|
|
|
|
`borgmatic check --force` to run checks unconditionally.
|
|
|
|
|
2022-05-28 22:42:19 +01:00
|
|
|
|
|
|
|
### Disabling checks
|
|
|
|
|
2019-02-04 06:20:59 +00:00
|
|
|
If that's still too slow, you can disable consistency checks entirely,
|
|
|
|
either for a single repository or for all repositories.
|
|
|
|
|
|
|
|
Disabling all consistency checks looks like this:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
consistency:
|
|
|
|
checks:
|
2022-05-28 22:42:19 +01:00
|
|
|
- name: disabled
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Or, if you have multiple repositories in your borgmatic configuration file,
|
|
|
|
you can keep running consistency checks, but only against a subset of the
|
|
|
|
repositories:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
consistency:
|
|
|
|
check_repositories:
|
|
|
|
- path/of/repository_to_check.borg
|
|
|
|
```
|
|
|
|
|
2019-09-19 19:50:29 +01:00
|
|
|
Finally, you can override your configuration file's consistency checks, and
|
|
|
|
run particular checks via the command-line. For instance:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
borgmatic check --only data --only extract
|
|
|
|
```
|
|
|
|
|
|
|
|
This is useful for running slow consistency checks on an infrequent basis,
|
2022-05-28 22:42:19 +01:00
|
|
|
separate from your regular checks. It is still subject to any configured
|
2022-05-29 03:29:33 +01:00
|
|
|
check frequencies unless the `--force` flag is used.
|
2019-09-19 19:50:29 +01:00
|
|
|
|
2019-02-05 04:53:47 +00:00
|
|
|
|
|
|
|
## Troubleshooting
|
|
|
|
|
|
|
|
### Broken pipe with remote repository
|
|
|
|
|
|
|
|
When running borgmatic on a large remote repository, you may receive errors
|
|
|
|
like the following, particularly while "borg check" is validating backups for
|
|
|
|
consistency:
|
|
|
|
|
|
|
|
```text
|
|
|
|
Write failed: Broken pipe
|
|
|
|
borg: Error: Connection closed by remote host
|
|
|
|
```
|
|
|
|
|
|
|
|
This error can be caused by an ssh timeout, which you can rectify by adding
|
|
|
|
the following to the `~/.ssh/config` file on the client:
|
|
|
|
|
|
|
|
```text
|
|
|
|
Host *
|
|
|
|
ServerAliveInterval 120
|
|
|
|
```
|
|
|
|
|
|
|
|
This should make the client keep the connection alive while validating
|
|
|
|
backups.
|