2019-02-04 06:20:59 +00:00
|
|
|
---
|
2022-08-19 07:06:51 +01:00
|
|
|
title: How to upgrade borgmatic and Borg
|
2020-08-21 22:27:47 +01:00
|
|
|
eleventyNavigation:
|
2022-08-19 07:06:51 +01:00
|
|
|
key: 📦 Upgrade borgmatic/Borg
|
2020-08-21 22:27:47 +01:00
|
|
|
parent: How-to guides
|
2022-06-16 23:30:53 +01:00
|
|
|
order: 12
|
2019-02-04 06:20:59 +00:00
|
|
|
---
|
2022-08-19 07:06:51 +01:00
|
|
|
## Upgrading borgmatic
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
In general, all you should need to do to upgrade borgmatic is run the
|
|
|
|
following:
|
|
|
|
|
|
|
|
```bash
|
2019-05-13 12:18:59 +01:00
|
|
|
sudo pip3 install --user --upgrade borgmatic
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
2019-11-06 17:31:00 +00:00
|
|
|
See below about special cases with old versions of borgmatic. Additionally, if
|
|
|
|
you installed borgmatic [without using `pip3 install
|
|
|
|
--user`](https://torsion.org/borgmatic/docs/how-to/set-up-backups/#other-ways-to-install),
|
|
|
|
then your upgrade process may be different.
|
|
|
|
|
|
|
|
|
|
|
|
### Upgrading your configuration
|
|
|
|
|
|
|
|
The borgmatic configuration file format is almost always backwards-compatible
|
|
|
|
from release to release without any changes, but you may still want to update
|
|
|
|
your configuration file when you upgrade to take advantage of new
|
|
|
|
configuration options. This is completely optional. If you prefer, you can add
|
|
|
|
new configuration options manually.
|
|
|
|
|
|
|
|
If you do want to upgrade your configuration file to include new options, use
|
|
|
|
the `generate-borgmatic-config` script with its optional `--source` flag that
|
|
|
|
takes the path to your original configuration file. If provided with this
|
|
|
|
path, `generate-borgmatic-config` merges your original configuration into the
|
|
|
|
generated configuration file, so you get all the newest options and comments.
|
|
|
|
|
|
|
|
Here's an example:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
generate-borgmatic-config --source config.yaml --destination config-new.yaml
|
|
|
|
```
|
|
|
|
|
|
|
|
New options start as commented out, so you can edit the file and decide
|
|
|
|
whether you want to use each one.
|
|
|
|
|
2019-11-12 20:32:32 +00:00
|
|
|
There are a few caveats to this process. First, when generating the new
|
|
|
|
configuration file, `generate-borgmatic-config` replaces any comments you've
|
|
|
|
written in your original configuration file with the newest generated
|
2019-11-06 17:31:00 +00:00
|
|
|
comments. Second, the script adds back any options you had originally deleted,
|
|
|
|
although it does so with the options commented out. And finally, any YAML
|
|
|
|
includes you've used in the source configuration get flattened out into a
|
|
|
|
single generated file.
|
|
|
|
|
|
|
|
As a safety measure, `generate-borgmatic-config` refuses to modify
|
|
|
|
configuration files in-place. So it's up to you to review the generated file
|
|
|
|
and, if desired, replace your original configuration file with it.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
### Upgrading from borgmatic 1.0.x
|
|
|
|
|
|
|
|
borgmatic changed its configuration file format in version 1.1.0 from
|
|
|
|
INI-style to YAML. This better supports validation, and has a more natural way
|
|
|
|
to express lists of values. To upgrade your existing configuration, first
|
2023-06-20 07:17:59 +01:00
|
|
|
upgrade to the last version of borgmatic to support converting configuration:
|
|
|
|
borgmatic 1.7.14.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
As of version 1.1.0, borgmatic no longer supports Python 2. If you were
|
|
|
|
already running borgmatic with Python 3, then you can upgrade borgmatic
|
|
|
|
in-place:
|
|
|
|
|
|
|
|
```bash
|
2023-06-20 07:17:59 +01:00
|
|
|
sudo pip3 install --user --upgrade borgmatic==1.7.14
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
But if you were running borgmatic with Python 2, uninstall and reinstall instead:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo pip uninstall borgmatic
|
2023-06-20 07:17:59 +01:00
|
|
|
sudo pip3 install --user borgmatic==1.7.14
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
The pip binary names for different versions of Python can differ, so the above
|
|
|
|
commands may need some tweaking to work on your machine.
|
|
|
|
|
|
|
|
|
|
|
|
Once borgmatic is upgraded, run:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
sudo upgrade-borgmatic-config
|
|
|
|
```
|
|
|
|
|
|
|
|
That will generate a new YAML configuration file at /etc/borgmatic/config.yaml
|
|
|
|
(by default) using the values from both your existing configuration and
|
|
|
|
excludes files. The new version of borgmatic will consume the YAML
|
|
|
|
configuration file instead of the old one.
|
|
|
|
|
2023-06-20 07:17:59 +01:00
|
|
|
Now you can upgrade to a newer version of borgmatic:
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
```bash
|
2019-05-13 12:18:59 +01:00
|
|
|
sudo pip3 install --user borgmatic
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
2022-08-19 07:06:51 +01:00
|
|
|
|
|
|
|
## Upgrading Borg
|
|
|
|
|
|
|
|
To upgrade to a new version of Borg, you can generally install a new version
|
|
|
|
the same way you installed the previous version, paying attention to any
|
|
|
|
instructions included with each Borg release changelog linked from the
|
2022-08-22 05:48:37 +01:00
|
|
|
[releases page](https://github.com/borgbackup/borg/releases). Some more major
|
|
|
|
Borg releases require additional steps that borgmatic can help with.
|
2022-08-19 07:06:51 +01:00
|
|
|
|
|
|
|
|
|
|
|
### Borg 1.2 to 2.0
|
|
|
|
|
|
|
|
<span class="minilink minilink-addedin">New in borgmatic version 1.7.0</span>
|
|
|
|
Upgrading Borg from 1.2 to 2.0 requires manually upgrading your existing Borg
|
|
|
|
1 repositories before use with Borg or borgmatic. Here's how you can
|
|
|
|
accomplish that.
|
|
|
|
|
|
|
|
Start by upgrading borgmatic as described above to at least version 1.7.0 and
|
|
|
|
Borg to 2.0. Then, rename your repository in borgmatic's configuration file to
|
|
|
|
a new repository path. The repository upgrade process does not occur
|
|
|
|
in-place; you'll create a new repository with a copy of your old repository's
|
|
|
|
data.
|
|
|
|
|
|
|
|
Let's say your original borgmatic repository configuration file looks something
|
|
|
|
like this:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
location:
|
|
|
|
repositories:
|
2023-03-28 05:49:31 +01:00
|
|
|
- path: original.borg
|
2022-08-19 07:06:51 +01:00
|
|
|
```
|
|
|
|
|
2023-03-28 05:49:31 +01:00
|
|
|
<span class="minilink minilink-addedin">Prior to version 1.7.10</span> Omit
|
|
|
|
the `path:` portion of the `repositories` list.
|
|
|
|
|
2022-08-19 07:06:51 +01:00
|
|
|
Change it to a new (not yet created) repository path:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
location:
|
|
|
|
repositories:
|
2023-03-28 05:49:31 +01:00
|
|
|
- path: upgraded.borg
|
2022-08-19 07:06:51 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Then, run the `rcreate` action (formerly `init`) to create that new Borg 2
|
|
|
|
repository:
|
|
|
|
|
|
|
|
```bash
|
2022-10-17 23:04:30 +01:00
|
|
|
borgmatic rcreate --verbosity 1 --encryption repokey-blake2-aes-ocb \
|
2022-08-19 07:06:51 +01:00
|
|
|
--source-repository original.borg --repository upgraded.borg
|
|
|
|
```
|
|
|
|
|
|
|
|
This creates an empty repository and doesn't actually transfer any data yet.
|
|
|
|
The `--source-repository` flag is necessary to reuse key material from your
|
|
|
|
Borg 1 repository so that the subsequent data transfer can work.
|
|
|
|
|
2022-10-17 23:04:30 +01:00
|
|
|
The `--encryption` value above selects the same chunk ID algorithm (`blake2`)
|
2023-02-27 07:22:23 +00:00
|
|
|
commonly used in Borg 1, thereby making deduplication work across transferred
|
|
|
|
archives and new archives.
|
|
|
|
|
|
|
|
If you get an error about "You must keep the same ID hash" from Borg, that
|
|
|
|
means the encryption value you specified doesn't correspond to your source
|
|
|
|
repository's chunk ID algorithm. In that case, try not using `blake2`:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
borgmatic rcreate --verbosity 1 --encryption repokey-aes-ocb \
|
|
|
|
--source-repository original.borg --repository upgraded.borg
|
|
|
|
```
|
|
|
|
|
|
|
|
Read about [Borg encryption
|
2023-02-27 00:44:43 +00:00
|
|
|
modes](https://borgbackup.readthedocs.io/en/2.0.0b5/usage/rcreate.html#encryption-mode-tldr)
|
2023-02-27 07:22:23 +00:00
|
|
|
for more details.
|
2022-10-17 23:04:30 +01:00
|
|
|
|
2022-08-19 07:06:51 +01:00
|
|
|
To transfer data from your original Borg 1 repository to your newly created
|
|
|
|
Borg 2 repository:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
borgmatic transfer --verbosity 1 --upgrader From12To20 --source-repository \
|
|
|
|
original.borg --repository upgraded.borg --dry-run
|
|
|
|
borgmatic transfer --verbosity 1 --upgrader From12To20 --source-repository \
|
|
|
|
original.borg --repository upgraded.borg
|
|
|
|
borgmatic transfer --verbosity 1 --upgrader From12To20 --source-repository \
|
|
|
|
original.borg --repository upgraded.borg --dry-run
|
|
|
|
```
|
|
|
|
|
|
|
|
The first command with `--dry-run` tells you what Borg is going to do during
|
|
|
|
the transfer, the second command actually performs the transfer/upgrade (this
|
|
|
|
might take a while), and the final command with `--dry-run` again provides
|
|
|
|
confirmation of success—or tells you if something hasn't been transferred yet.
|
|
|
|
|
|
|
|
Note that by omitting the `--upgrader` flag, you can also do archive transfers
|
2022-12-10 20:59:44 +00:00
|
|
|
between related Borg 2 repositories without upgrading, even down to individual
|
2022-08-19 07:06:51 +01:00
|
|
|
archives. For more on that functionality, see the [Borg transfer
|
2023-02-27 00:44:43 +00:00
|
|
|
documentation](https://borgbackup.readthedocs.io/en/2.0.0b5/usage/transfer.html).
|
2022-08-19 07:06:51 +01:00
|
|
|
|
|
|
|
That's it! Now you can use your new Borg 2 repository as normal with
|
|
|
|
borgmatic. If you've got multiple repositories, repeat the above process for
|
|
|
|
each.
|