diff --git a/backups/mastodon_db_backup.sh b/backups/mastodon_db_backup.sh new file mode 100644 index 0000000000000000000000000000000000000000..5b4fd71085445f439dc4ffd878eb07cb339c7f95 --- /dev/null +++ b/backups/mastodon_db_backup.sh @@ -0,0 +1,36 @@ +#!/bin/bash + +# A script which backs up the mastodon database(s) + +container=mastodon_db +backupdir=/var/vol2/postgres + +# This performs a cyclic dump to files with the container and date in the name +# It also creates a link to a file containing the backup sequence number 0 or 1 +# which alternates (computed by modular division from the days since the epoch). +# Thus by deleting the linked file we can maintain just two backup files. +backup() { + local cname=$1 + local seqno="$(( $(date +%s) / 86400 % 2 ))" + local link="db-backup.$seqno.sql.gz" + local file="db-backup.(date +%F_%R)-${cname}.sql.gz" + + echo "Backing up $cname -> $file @ $(date +%F_%R)" + + # delete previous backup with same seqno, don't complain if missing + rm -f $(readlink -f "$backupdir/$link") + + # create new backup file + docker exec pg_dumpall -U postgres -c -v | gzip >"$backupdir/$file" + status=$? + + # link the sequence number to it + ln -sf "$backupdir/"{"$file","$link"} + echo "Done. (Status $status @$(date +%F_%R))" +} + +# Iterate over all matching container names +for cname in $(docker container ls -f name=$container --format '{{.Names}}') +do + echo backup $cname +done