Compare commits
No commits in common. "077ed7c9caf5b53a7b7f20adc6233e79c8a7b421" and "66374b490a51d721c16d058073acdc80373abbaa" have entirely different histories.
077ed7c9ca
...
66374b490a
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +0,0 @@
|
|||||||
*.sw*
|
|
@ -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
|
|
33
README.md
33
README.md
@ -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).
|
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
|
## Usage
|
||||||
|
|
||||||
Simply write a `docker-compose.yml` along the following lines:
|
Simply write a `docker-compose.yml` along the following lines:
|
||||||
|
|
||||||
```
|
```
|
||||||
|
version: '2'
|
||||||
|
|
||||||
services:
|
services:
|
||||||
filebackup:
|
serverbackup:
|
||||||
image: wilw/fs-backup
|
image: wilw/fs-backup
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- /home/user:/backupdir
|
- /home/user:/backupdir
|
||||||
environment:
|
environment:
|
||||||
# ... Your Restic configuration. E.g.:
|
|
||||||
- AWS_ACCESS_KEY_ID=accesskey
|
- AWS_ACCESS_KEY_ID=accesskey
|
||||||
- AWS_SECRET_ACCESS_KEY=secretaccesskey
|
- AWS_SECRET_ACCESS_KEY=secretaccesskey
|
||||||
- RESTIC_REPOSITORY=s3:endpoint/bucket
|
- 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.
|
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.
|
You can now bring up the container: `docker-compose up -d`.
|
||||||
* `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`.
|
|
||||||
|
|
||||||
**Important**
|
**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:
|
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
|
## 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:
|
The image `wilw/fs-backup` (which you can use as described above) does the following:
|
||||||
|
|
||||||
* Backs-up `/backupdir` hourly
|
* 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.
|
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
|
## 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
|
## More
|
||||||
|
|
||||||
|
@ -1,11 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
set -x # Print commands
|
|
||||||
set -e # Exit on error
|
|
||||||
set -u # Exit on undefined variable
|
|
||||||
|
|
||||||
# Perform the backup
|
# Perform the backup
|
||||||
/usr/bin/restic backup -q --host $RESTIC_HOSTNAME /backupdir
|
/usr/bin/restic backup -q --host $RESTIC_HOSTNAME /backupdir
|
||||||
|
|
||||||
# Prune old backups
|
# 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
|
Loading…
Reference in New Issue
Block a user