#!/bin/bash # Логический бэкап PostgreSQL (Gitea) из контейнера 103. # Запускать на хосте Proxmox под root. Использует pct exec. # Результат: /mnt/backup/databases/ct103-gitea/gitea-db-YYYYMMDD-HHMM.sql.gz set -e export PATH="/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:${PATH:-}" CT_ID=103 BACKUP_DIR="/mnt/backup/databases/ct103-gitea" RETENTION_DAYS=14 PG_CONTAINER="gitea-db-1" if [ "$(id -u)" -ne 0 ]; then echo "Запускайте под root." exit 1 fi # Минимальный размер дампа (байт). Пустой gzip ≈ 20 байт — значит pg_dump не отдал данные. MIN_BACKUP_BYTES=512 mkdir -p "$BACKUP_DIR" DATE=$(date +%Y%m%d-%H%M) OUTPUT="$BACKUP_DIR/gitea-db-$DATE.sql.gz" ERR=$(mktemp) trap "rm -f '$ERR'" EXIT # PGPASSWORD из Vaultwarden (объект GITEA, пароль). См. docs/backup/proxmox-phase1-backup.md PG_ENV_ARGS="" BW_MASTER_PASSWORD_FILE="${BW_MASTER_PASSWORD_FILE:-/root/.bw-master}" if [ -f "$BW_MASTER_PASSWORD_FILE" ] && command -v bw >/dev/null 2>&1; then export BW_SESSION=$(bw unlock --passwordfile "$BW_MASTER_PASSWORD_FILE" --raw 2>/dev/null) || true if [ -n "${BW_SESSION:-}" ]; then PGPASS=$(bw get password "GITEA" 2>/dev/null) [ -n "$PGPASS" ] && PG_ENV_ARGS="-e PGPASSWORD=$PGPASS" fi fi pct exec $CT_ID -- docker exec $PG_ENV_ARGS "$PG_CONTAINER" pg_dump -U gitea gitea 2>"$ERR" | gzip > "$OUTPUT" SIZE_BYTES=$(stat -c%s "$OUTPUT" 2>/dev/null || echo 0) if [ -s "$OUTPUT" ] && [ "$SIZE_BYTES" -ge "$MIN_BACKUP_BYTES" ]; then echo "Создан: $OUTPUT ($(du --apparent-size -h "$OUTPUT" | cut -f1))" else echo "Ошибка: дамп пустой или слишком мал (${SIZE_BYTES} байт). Проверьте контейнер $PG_CONTAINER и пароль БД в Vaultwarden (GITEA)." [ -s "$ERR" ] && cat "$ERR" >&2 rm -f "$OUTPUT" exit 1 fi find "$BACKUP_DIR" -name 'gitea-db-*.sql.gz' -mtime +$RETENTION_DAYS -delete NOTIFY_SCRIPT="${NOTIFY_SCRIPT:-/root/scripts/notify-telegram.sh}" if [ -x "$NOTIFY_SCRIPT" ]; then SIZE=$(du --apparent-size -h "$OUTPUT" | cut -f1) SIZE_BYTES=$(stat -c%s "$OUTPUT" 2>/dev/null || echo 0) BODY="Резервное копирование завершено. Объекты: дамп БД Gitea (PostgreSQL). Размер копии: ${SIZE}." [ "$SIZE_BYTES" -lt 10240 ] 2>/dev/null && BODY="${BODY} ⚠️ Подозрительно малый размер — проверьте контейнер gitea-db-1 и наличие данных в БД." "$NOTIFY_SCRIPT" "🗄️ Gitea (БД)" "$BODY" || true fi