backup forgejo and portainer data

add backup scripts for forgejo and portainer
make full-backup.sh execute them
add git specific config files to .gitignore
This commit is contained in:
ZoopaMario 2024-09-01 18:47:37 +02:00 committed by ZoopaMario
parent 1cbc61c6f4
commit 237e06db4c
4 changed files with 93 additions and 1 deletions

2
.gitignore vendored
View file

@ -1,2 +1,4 @@
.gitignore
.gitconfig
*.env
*.log

45
forgejo/forgejo-backup.sh Executable file
View file

@ -0,0 +1,45 @@
#!/bin/bash
SCRIPT_ABS_LOCATION=$(realpath "$(dirname "${0}")")
source $SCRIPT_ABS_LOCATION/forgejo-backup.env
source $SCRIPT_ABS_LOCATION/../logger.sh
# Container Names
APP_CONTAINER="forgejo"
BACKUP_CONTAINER="duplicati"
SOURCE_DIR="/mnt/data/forgejo"
BACKUP_DESTINATION="$BACKUP_DESTINATION"
BACKUP_ENCR_PASSPHRASE="$BACKUP_ENCR_PASSPHRASE"
# Cloud Storage Authentication
SFTP_USERNAME="$SFTP_USERNAME"
SFTP_PASSWORD="$SFTP_PASSWORD"
SFTP_FINGERPRINT="$SFTP_FINGERPRINT"
# Log file
LOG_FILE="$SCRIPT_ABS_LOCATION/forgejo-backup.log"
# Stop forgejo container
log "Stopping forgejo container..."
docker stop $APP_CONTAINER || { log "Error: Failed to stop forgejo."; exit 1; }
# Backup all files to target destination
log "Backing up forgejo files (including the SQLite database)..."
docker exec $BACKUP_CONTAINER \
duplicati-cli backup \
ssh://$BACKUP_DESTINATION \
$SOURCE_DIR \
--backup-name="forgejo backup" \
--keep-versions=7 \
--auth-username=$SFTP_USERNAME \
--auth-password=$SFTP_PASSWORD \
--passphrase=$BACKUP_ENCR_PASSPHRASE \
--ssh-fingerprint="$SFTP_FINGERPRINT" \
--prefix="forgejo" || { log "Error: Failed to backup forgejo files and database."; exit 1; }
# Turn off Maintenance Mode
log "Starting forgejo container..."
docker start $APP_CONTAINER || { log "Error: Failed to start forgejo container."; exit 1; }
log "Forgejo backup completed successfully."

View file

@ -3,7 +3,7 @@
SCRIPT_ABS_LOCATION=$(realpath "$(dirname "${0}")")
# Define an array of application names
declare -a apps=("cryptpad" "immich" "duplicati" "nextcloud" "vaultwarden")
declare -a apps=("cryptpad" "immich" "duplicati" "nextcloud" "vaultwarden" "forgejo" "portainer")
# Function to execute the backup script for each application
backup_app() {

45
portainer/portainer-backup.sh Executable file
View file

@ -0,0 +1,45 @@
#!/bin/bash
SCRIPT_ABS_LOCATION=$(realpath "$(dirname "${0}")")
source $SCRIPT_ABS_LOCATION/portainer-backup.env
source $SCRIPT_ABS_LOCATION/../logger.sh
# Container Names
APP_CONTAINER="portainer"
BACKUP_CONTAINER="duplicati"
SOURCE_DIR="/volumes/portainer"
BACKUP_DESTINATION="$BACKUP_DESTINATION"
BACKUP_ENCR_PASSPHRASE="$BACKUP_ENCR_PASSPHRASE"
# Cloud Storage Authentication
SFTP_USERNAME="$SFTP_USERNAME"
SFTP_PASSWORD="$SFTP_PASSWORD"
SFTP_FINGERPRINT="$SFTP_FINGERPRINT"
# Log file
LOG_FILE="$SCRIPT_ABS_LOCATION/portainer-backup.log"
# Stop portainer container
log "Stopping portainer container..."
docker stop $APP_CONTAINER || { log "Error: Failed to stop portainer."; exit 1; }
# Backup all files to target destination
log "Backing up portainer files (including the SQLite database)..."
docker exec $BACKUP_CONTAINER \
duplicati-cli backup \
ssh://$BACKUP_DESTINATION \
$SOURCE_DIR \
--backup-name="portainer backup" \
--keep-versions=7 \
--auth-username=$SFTP_USERNAME \
--auth-password=$SFTP_PASSWORD \
--passphrase=$BACKUP_ENCR_PASSPHRASE \
--ssh-fingerprint="$SFTP_FINGERPRINT" \
--prefix="portainer" || { log "Error: Failed to backup portainer files and database."; exit 1; }
# Turn off Maintenance Mode
log "Starting portainer container..."
docker start $APP_CONTAINER || { log "Error: Failed to start portainer container."; exit 1; }
log "portainer backup completed successfully."