added backup script
This commit is contained in:
parent
fa6a36c88b
commit
6a585de6db
47
backup.sh
Executable file
47
backup.sh
Executable file
|
|
@ -0,0 +1,47 @@
|
|||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
# Where this script lives (Forgejo project root)
|
||||
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
||||
cd "$SCRIPT_DIR"
|
||||
|
||||
BACKUP_DIR="$SCRIPT_DIR/backup"
|
||||
TIMESTAMP="$(date +%Y-%m-%d_%H-%M-%S)"
|
||||
BACKUP_FILE="$BACKUP_DIR/forgejo-backup-${TIMESTAMP}.tar.gz"
|
||||
|
||||
echo "=== Forgejo backup ==="
|
||||
echo "Project dir : $SCRIPT_DIR"
|
||||
echo "Backup dir : $BACKUP_DIR"
|
||||
echo "Backup file : $BACKUP_FILE"
|
||||
echo
|
||||
|
||||
# 1) Ensure backup dir exists
|
||||
mkdir -p "$BACKUP_DIR"
|
||||
|
||||
# 2) Stop Forgejo (short downtime, but consistent backup)
|
||||
echo "[1/3] Stopping Forgejo containers..."
|
||||
docker compose down
|
||||
|
||||
# 3) Create archive of data + config
|
||||
# Adjust the list if you add more config files
|
||||
echo "[2/3] Creating backup archive..."
|
||||
tar -czf "$BACKUP_FILE" \
|
||||
forgejo \
|
||||
docker-compose.yml \
|
||||
.gitignore \
|
||||
README.md \
|
||||
.git 2>/dev/null || true # ignore .git if it causes trouble
|
||||
|
||||
echo "[OK] Backup created: $BACKUP_FILE"
|
||||
|
||||
# 4) Start Forgejo again
|
||||
echo "[3/3] Starting Forgejo containers..."
|
||||
docker compose up -d
|
||||
|
||||
echo "=== Done ==="
|
||||
|
||||
# 5) Optional: keep only last 7 backups, delete older ones
|
||||
echo "Cleaning up old backups (keep last 7)..."
|
||||
ls -1t "$BACKUP_DIR"/forgejo-backup-*.tar.gz 2>/dev/null | tail -n +8 | xargs -r rm -f
|
||||
|
||||
echo "Backup finished successfully."
|
||||
Loading…
Reference in a new issue