diff options
author | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-01-26 21:48:48 +0100 |
---|---|---|
committer | Quentin Dufour <quentin@deuxfleurs.fr> | 2022-01-26 21:48:48 +0100 |
commit | a13a02c45ca212c7ac0aae6dfa510219b6c9f46c (patch) | |
tree | 7b69073252bf9f526086682a9780ca1fd4784319 /app/backup | |
parent | 453b633268eaf10041d557b10c5e30505f028603 (diff) | |
download | infrastructure-a13a02c45ca212c7ac0aae6dfa510219b6c9f46c.tar.gz infrastructure-a13a02c45ca212c7ac0aae6dfa510219b6c9f46c.zip |
Add a backup script for emails
Diffstat (limited to 'app/backup')
5 files changed, 56 insertions, 0 deletions
diff --git a/app/backup/deploy/backup-daily.hcl b/app/backup/deploy/backup-daily.hcl new file mode 100644 index 0000000..a1c2f89 --- /dev/null +++ b/app/backup/deploy/backup-daily.hcl @@ -0,0 +1,52 @@ +job "backup_daily" { + datacenters = ["dc1"] + type = "batch" + periodic { + cron = "@daily" + // Do not allow overlapping runs. + prohibit_overlap = true + } + + task "backup-dovecot" { + constraint { + attribute = "${attr.unique.hostname}" + operator = "=" + value = "digitale" + } + + driver = "docker" + + config { + image = "restic/restic:0.12.1" + entrypoint = [ "/bin/sh", "-c" ] + args = [ "restic backup /mail && restic forget --keep-within 1m1d --keep-within-weekly 3m --keep-within-monthly 1y ; restic prune --max-unused 50% --max-repack-size 2G ; restic check" ] + volumes = [ + "/mnt/ssd/mail:/mail" + ] + } + + + template { + data = <<EOH +AWS_ACCESS_KEY_ID={{ key "secrets/email/dovecot/backup_aws_access_key_id" }} +AWS_SECRET_ACCESS_KEY={{ key "secrets/email/dovecot/backup_aws_secret_access_key" }} +RESTIC_REPOSITORY={{ key "secrets/email/dovecot/backup_restic_repository" }} +RESTIC_PASSWORD={{ key "secrets/email/dovecot/backup_restic_password" }} +EOH + + destination = "secrets/env_vars" + env = true + } + + resources { + memory = 200 + } + + restart { + attempts = 2 + interval = "30m" + delay = "15s" + mode = "fail" + } + } +} diff --git a/app/backup/secrets/email/dovecot/backup_aws_access_key_id b/app/backup/secrets/email/dovecot/backup_aws_access_key_id new file mode 100644 index 0000000..9ae6adf --- /dev/null +++ b/app/backup/secrets/email/dovecot/backup_aws_access_key_id @@ -0,0 +1 @@ +USER AWS Acces Key ID diff --git a/app/backup/secrets/email/dovecot/backup_aws_secret_access_key b/app/backup/secrets/email/dovecot/backup_aws_secret_access_key new file mode 100644 index 0000000..ac95906 --- /dev/null +++ b/app/backup/secrets/email/dovecot/backup_aws_secret_access_key @@ -0,0 +1 @@ +USER AWS Secret Access key diff --git a/app/backup/secrets/email/dovecot/backup_restic_password b/app/backup/secrets/email/dovecot/backup_restic_password new file mode 100644 index 0000000..c19a4a3 --- /dev/null +++ b/app/backup/secrets/email/dovecot/backup_restic_password @@ -0,0 +1 @@ +USER Restic backup password to encrypt data diff --git a/app/backup/secrets/email/dovecot/backup_restic_repository b/app/backup/secrets/email/dovecot/backup_restic_repository new file mode 100644 index 0000000..0434a15 --- /dev/null +++ b/app/backup/secrets/email/dovecot/backup_restic_repository @@ -0,0 +1 @@ +USER Restic Repository URL, check op_guide/backup-minio to see the format |