2019-02-04 06:20:59 +00:00
|
|
|
---
|
2019-10-23 23:35:37 +01:00
|
|
|
title: How to add preparation and cleanup steps to backups
|
2020-08-21 22:27:47 +01:00
|
|
|
eleventyNavigation:
|
2022-05-20 19:11:35 +01:00
|
|
|
key: 🧹 Add preparation and cleanup steps
|
2020-08-21 22:27:47 +01:00
|
|
|
parent: How-to guides
|
2022-06-16 23:30:53 +01:00
|
|
|
order: 9
|
2019-02-04 06:20:59 +00:00
|
|
|
---
|
|
|
|
## Preparation and cleanup hooks
|
|
|
|
|
2022-04-22 06:08:25 +01:00
|
|
|
If you find yourself performing preparation tasks before your backup runs, or
|
2019-10-23 23:35:37 +01:00
|
|
|
cleanup work afterwards, borgmatic hooks may be of interest. Hooks are shell
|
2022-04-22 06:08:25 +01:00
|
|
|
commands that borgmatic executes for you at various points as it runs, and
|
|
|
|
they're configured in the `hooks` section of your configuration file. But if
|
|
|
|
you're looking to backup a database, it's probably easier to use the [database
|
|
|
|
backup
|
2019-10-23 23:35:37 +01:00
|
|
|
feature](https://torsion.org/borgmatic/docs/how-to/backup-your-databases/)
|
|
|
|
instead.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
2019-10-23 23:35:37 +01:00
|
|
|
You can specify `before_backup` hooks to perform preparation steps before
|
|
|
|
running backups, and specify `after_backup` hooks to perform cleanup steps
|
|
|
|
afterwards. Here's an example:
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
hooks:
|
|
|
|
before_backup:
|
2019-10-23 23:35:37 +01:00
|
|
|
- mount /some/filesystem
|
2019-02-04 06:20:59 +00:00
|
|
|
after_backup:
|
2019-10-23 23:35:37 +01:00
|
|
|
- umount /some/filesystem
|
2019-02-04 06:20:59 +00:00
|
|
|
```
|
|
|
|
|
2023-06-03 18:19:34 +01:00
|
|
|
If your command contains a special YAML character such as a colon, you may
|
|
|
|
need to quote the entire string (or use a [multiline
|
|
|
|
string](https://yaml-multiline.info/)) to avoid an error:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
hooks:
|
|
|
|
before_backup:
|
|
|
|
- "echo Backup: start"
|
|
|
|
```
|
|
|
|
|
2022-06-17 04:49:15 +01:00
|
|
|
<span class="minilink minilink-addedin">New in version 1.6.0</span> The
|
|
|
|
`before_backup` and `after_backup` hooks each run once per repository in a
|
2022-04-22 06:08:25 +01:00
|
|
|
configuration file. `before_backup` hooks runs right before the `create`
|
|
|
|
action for a particular repository, and `after_backup` hooks run afterwards,
|
|
|
|
but not if an error occurs in a previous hook or in the backups themselves.
|
2022-04-23 03:58:28 +01:00
|
|
|
(Prior to borgmatic 1.6.0, these hooks instead ran once per configuration file
|
|
|
|
rather than once per repository.)
|
2019-02-04 06:20:59 +00:00
|
|
|
|
2022-02-09 22:33:12 +00:00
|
|
|
There are additional hooks that run before/after other actions as well. For
|
2022-04-22 06:08:25 +01:00
|
|
|
instance, `before_prune` runs before a `prune` action for a repository, while
|
|
|
|
`after_prune` runs after it.
|
2020-01-27 19:07:07 +00:00
|
|
|
|
2022-08-22 05:48:37 +01:00
|
|
|
<span class="minilink minilink-addedin">New in version 1.7.0</span> The
|
|
|
|
`before_actions` and `after_actions` hooks run before/after all the actions
|
|
|
|
(like `create`, `prune`, etc.) for each repository. These hooks are a good
|
|
|
|
place to run per-repository steps like mounting/unmounting a remote
|
|
|
|
filesystem.
|
|
|
|
|
|
|
|
|
2022-03-14 20:34:14 +00:00
|
|
|
## Variable interpolation
|
|
|
|
|
|
|
|
The before and after action hooks support interpolating particular runtime
|
|
|
|
variables into the hook command. Here's an example that assumes you provide a
|
|
|
|
separate shell script:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
hooks:
|
|
|
|
after_prune:
|
2022-04-22 06:08:25 +01:00
|
|
|
- record-prune.sh "{configuration_filename}" "{repository}"
|
2022-03-14 20:34:14 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
In this example, when the hook is triggered, borgmatic interpolates runtime
|
|
|
|
values into the hook command: the borgmatic configuration filename and the
|
2022-04-22 06:08:25 +01:00
|
|
|
paths of the current Borg repository. Here's the full set of supported
|
2022-03-14 20:34:14 +00:00
|
|
|
variables you can use here:
|
|
|
|
|
|
|
|
* `configuration_filename`: borgmatic configuration filename in which the
|
|
|
|
hook was defined
|
2023-04-06 21:58:37 +01:00
|
|
|
* `log_file`
|
|
|
|
<span class="minilink minilink-addedin">New in version 1.7.12</span>:
|
|
|
|
path of the borgmatic log file, only set when the `--log-file` flag is used
|
2022-04-22 06:08:25 +01:00
|
|
|
* `repository`: path of the current repository as configured in the current
|
|
|
|
borgmatic configuration file
|
2022-03-14 20:34:14 +00:00
|
|
|
|
2022-06-16 23:30:53 +01:00
|
|
|
Note that you can also interpolate in [arbitrary environment
|
|
|
|
variables](https://torsion.org/borgmatic/docs/how-to/provide-your-passwords/).
|
|
|
|
|
|
|
|
|
2022-03-14 20:50:22 +00:00
|
|
|
## Global hooks
|
|
|
|
|
2019-09-29 00:18:10 +01:00
|
|
|
You can also use `before_everything` and `after_everything` hooks to perform
|
|
|
|
global setup or cleanup:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
hooks:
|
|
|
|
before_everything:
|
|
|
|
- set-up-stuff-globally
|
|
|
|
after_everything:
|
|
|
|
- clean-up-stuff-globally
|
|
|
|
```
|
|
|
|
|
|
|
|
`before_everything` hooks collected from all borgmatic configuration files run
|
|
|
|
once before all configuration files (prior to all actions), but only if there
|
|
|
|
is a `create` action. An error encountered during a `before_everything` hook
|
|
|
|
causes borgmatic to exit without creating backups.
|
|
|
|
|
|
|
|
`after_everything` hooks run once after all configuration files and actions,
|
|
|
|
but only if there is a `create` action. It runs even if an error occurs during
|
|
|
|
a backup or a backup hook, but not if an error occurs during a
|
|
|
|
`before_everything` hook.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
2022-03-14 20:34:14 +00:00
|
|
|
## Error hooks
|
|
|
|
|
2019-07-19 17:25:01 +01:00
|
|
|
borgmatic also runs `on_error` hooks if an error occurs, either when creating
|
2019-10-15 18:49:14 +01:00
|
|
|
a backup or running a backup hook. See the [monitoring and alerting
|
2019-10-23 23:35:37 +01:00
|
|
|
documentation](https://torsion.org/borgmatic/docs/how-to/monitor-your-backups/)
|
2019-10-01 20:23:16 +01:00
|
|
|
for more information.
|
2019-09-29 00:18:10 +01:00
|
|
|
|
2019-06-12 21:09:04 +01:00
|
|
|
## Hook output
|
|
|
|
|
2019-06-27 22:41:21 +01:00
|
|
|
Any output produced by your hooks shows up both at the console and in syslog
|
|
|
|
(when run in a non-interactive console). For more information, read about <a
|
2019-10-23 23:35:37 +01:00
|
|
|
href="https://torsion.org/borgmatic/docs/how-to/inspect-your-backups/">inspecting
|
2019-06-12 21:09:04 +01:00
|
|
|
your backups</a>.
|
2019-02-04 06:20:59 +00:00
|
|
|
|
|
|
|
## Security
|
|
|
|
|
|
|
|
An important security note about hooks: borgmatic executes all hook commands
|
|
|
|
with the user permissions of borgmatic itself. So to prevent potential shell
|
|
|
|
injection or privilege escalation, do not forget to set secure permissions
|
2019-09-29 00:18:10 +01:00
|
|
|
on borgmatic configuration files (`chmod 0600`) and scripts (`chmod 0700`)
|
|
|
|
invoked by hooks.
|