Compare commits

..

No commits in common. "077ed7c9caf5b53a7b7f20adc6233e79c8a7b421" and "66374b490a51d721c16d058073acdc80373abbaa" have entirely different histories.

4 changed files with 20 additions and 34 deletions

1
.gitignore vendored
View File

@ -1 +0,0 @@
*.sw*

View File

@ -1,12 +0,0 @@
steps:
- name: build-image
image: woodpeckerci/plugin-docker-buildx
secrets: [docker_username, docker_password]
settings:
repo: wilw/fs-backup
dockerfile: Dockerfile
platforms: linux/arm64,linux/amd64
when:
- event: push
branch: main

View File

@ -1,24 +1,25 @@
# File/directory Backup
# Filesystem Backup
A simple script for backing up a directory periodically and securely using [Restic](https://restic.net).
This script backs-up a directory to any Restic backend that you can configure using environment variables. It creates a new snapshot once per hour.
This script backs-up a directory to an S3-compatible bucket (i.e. it doesn't have to be Amazon S3), with hourly snapshots.
Note: I call this `fs-backup` even though it generally works with specific files/directories on a filesystem rather than the filesystem as a whole.
I call this `fs-backup` even though it works with files/directories on a filesystem (as opposed to `db-backup`), rather than the filesystem as a whole.
## Usage
Simply write a `docker-compose.yml` along the following lines:
```
version: '2'
services:
filebackup:
serverbackup:
image: wilw/fs-backup
restart: always
volumes:
- /home/user:/backupdir
environment:
# ... Your Restic configuration. E.g.:
- AWS_ACCESS_KEY_ID=accesskey
- AWS_SECRET_ACCESS_KEY=secretaccesskey
- RESTIC_REPOSITORY=s3:endpoint/bucket
@ -30,22 +31,22 @@ services:
The container will backup the directory mounted to `/backupdir`. In the example above I am backing up a home directory, but change this to whatever you need.
Also change the variables in the `environment` block to match what's needed for your chosen Restic backend. Refer to [the documentation](https://restic.readthedocs.io/en/stable/030_preparing_a_new_repo.html) for more information.
Also change the variables in the `environment` block:
At a minimum we recommend setting the following:
* AWS_ACCESS_KEY_ID: Use the access key provided by your bucket provider
* AWS_SECRET_ACCESS_KEY: Use the secret key provided by your bucket provider
* RESTIC_REPOSITORY: The repository name. For a Linode Object Storage bucket you can use `s3:eu-central-1.linodeobjects.com/bucket-name`. See below for other examples.
* RESTIC_PASSWORD: The string used to encrypt/protect your data. Use a long complex string, and don't lose it (or you'll lose your backups)
* RESTIC_HOSTNAME: Set this to an identifier for the machine. If you don't, the Docker container ID will be used, which changes on each startup, which isn't ideal.
* `RESTIC_REPOSITORY`: The repository name. For a Linode Object Storage bucket you can use `s3:eu-central-1.linodeobjects.com/bucket-name`. See below for other examples.
* `RESTIC_PASSWORD`: The string used to encrypt/protect your data. Use a long complex string, and don't lose it (or you'll lose your backups)
* `RESTIC_HOSTNAME`: Set this to an identifier for the machine. If you don't, the Docker container ID will be used, which changes on each startup, which isn't ideal.
You can now bring up the container: `docker compose up -d`.
You can now bring up the container: `docker-compose up -d`.
**Important**
After the container is launched for the first time, you'll need to initialize the repository. You only need to do this once for each repository. To do so, run the following:
```
docker compose exec -it filebackup /usr/bin/restic init
docker-compose exec serverbackup /usr/bin/restic init
```
## Defaults
@ -53,7 +54,7 @@ docker compose exec -it filebackup /usr/bin/restic init
The image `wilw/fs-backup` (which you can use as described above) does the following:
* Backs-up `/backupdir` hourly
* Keeps 24 hourly, 10 daily, 6 weekly, and 6 monthly backups, and prunes the rest
* Keeps 24 hourly and 10 daily backups, and prunes the rest
To change this behaviour, just edit the `backup.sh` file and rebuild the image.
@ -70,7 +71,9 @@ Refer to [the documentation](https://restic.readthedocs.io/en/stable/030_prepari
## Backup different directories
If you have multiple separate directories you need to backup, just launch several versions of the image by specifying a new service for each in your `docker-compose.yml`. You could use the `RESTIC_HOSTNAME` variable to differentiate between them.
If you have multiple separate directories you need to backup, just launch several versions of the image by specifying a new service for each in your `docker-compose.yml`.
AFAIK, you need a new bucket for each repository.
## More

View File

@ -1,11 +1,7 @@
#!/bin/sh
set -x # Print commands
set -e # Exit on error
set -u # Exit on undefined variable
# Perform the backup
/usr/bin/restic backup -q --host $RESTIC_HOSTNAME /backupdir
# Prune old backups
/usr/bin/restic forget -q --keep-hourly 24 --keep-daily 10 --keep-weekly 6 --keep-monthly 6 --prune
/usr/bin/restic forget -q --keep-hourly 24 --keep-daily 10 --prune