| 1 |
|
| 2 |
|
| 3 |
|
| 4 |
|
| 5 |
|
| 6 |
|
| 7 |
|
| 8 |
|
| 9 |
|
| 10 |
|
| 11 |
|
| 12 |
|
| 13 |
|
| 14 |
|
| 15 |
|
| 16 |
|
| 17 |
|
| 18 |
set -euo pipefail |
| 19 |
|
| 20 |
DB_NAME="${1:-makenotwork}" |
| 21 |
DB_USER="$DB_NAME" |
| 22 |
BACKUP_DIR="/var/lib/mnw/backups/${DB_NAME}" |
| 23 |
RETENTION_DAYS=30 |
| 24 |
|
| 25 |
TIMESTAMP=$(date +%Y%m%d-%H%M%S) |
| 26 |
BACKUP_FILE="${BACKUP_DIR}/${DB_NAME}-${TIMESTAMP}.sql.gz" |
| 27 |
|
| 28 |
echo "[$(date -Iseconds)] Starting backup of ${DB_NAME}..." |
| 29 |
|
| 30 |
mkdir -p "$BACKUP_DIR" |
| 31 |
|
| 32 |
|
| 33 |
cd "$BACKUP_DIR" |
| 34 |
|
| 35 |
pg_dump -U "$DB_USER" "$DB_NAME" | gzip > "$BACKUP_FILE" |
| 36 |
|
| 37 |
FILESIZE=$(stat -c%s "$BACKUP_FILE" 2>/dev/null || stat -f%z "$BACKUP_FILE" 2>/dev/null) |
| 38 |
if [ "$FILESIZE" -lt 100 ]; then |
| 39 |
echo "[$(date -Iseconds)] ERROR: Backup file suspiciously small (${FILESIZE} bytes)" |
| 40 |
exit 1 |
| 41 |
fi |
| 42 |
|
| 43 |
echo "[$(date -Iseconds)] Backup complete: $BACKUP_FILE ($(du -h "$BACKUP_FILE" | cut -f1))" |
| 44 |
|
| 45 |
|
| 46 |
|
| 47 |
|
| 48 |
LATEST="${BACKUP_DIR}/latest.sql.gz" |
| 49 |
ln -f "$BACKUP_FILE" "${LATEST}.new" |
| 50 |
mv -Tf "${LATEST}.new" "$LATEST" |
| 51 |
|
| 52 |
DELETED=$(find "$BACKUP_DIR" -name "${DB_NAME}-*.sql.gz" -mtime +${RETENTION_DAYS} -delete -print | wc -l) |
| 53 |
if [ "$DELETED" -gt 0 ]; then |
| 54 |
echo "[$(date -Iseconds)] Pruned $DELETED ${DB_NAME} backup(s) older than ${RETENTION_DAYS} days" |
| 55 |
fi |
| 56 |
|
| 57 |
TOTAL=$(find "$BACKUP_DIR" -name "${DB_NAME}-*.sql.gz" | wc -l) |
| 58 |
echo "[$(date -Iseconds)] Total ${DB_NAME} backups on disk: $TOTAL" |
| 59 |
|
| 60 |
|
| 61 |
SCRIPT_DIR="$(cd "$(dirname "$0")" && pwd)" |
| 62 |
OFFSITE_SCRIPT="${SCRIPT_DIR}/sync-backup-offsite.sh" |
| 63 |
if [ -x "$OFFSITE_SCRIPT" ]; then |
| 64 |
"$OFFSITE_SCRIPT" "$DB_NAME" "$BACKUP_FILE" || true |
| 65 |
fi |
| 66 |
|