Hier ist das funktionierende Skript, das ich zur Wiederherstellung von Prod nach Dev und Test verwende:
#!/bin/sh
set +x
set -e
# Dieses Skript stellt das neueste produktive Backup in der Test-/Dev-Umgebung wieder her
CONTAINER_NAME=app-test
LATEST_BACKUP=$(mc ls s3/backup-prod/default | tail -n 1 | cut -d ' ' -f 5)
mc cp s3/backup-prod/default/${LATEST_BACKUP} /tmp
# sicherstellen, dass /var/www/discourse/public/backups/default/ existiert und den richtigen Besitz hat
docker exec -i ${CONTAINER_NAME} sh -c "mkdir -p /var/www/discourse/public/backups/default/ && chown -R discourse:www-data /var/www/discourse/public/backups/default/"
cat /tmp/${LATEST_BACKUP} | docker exec -i ${CONTAINER_NAME} sh -c "cat - > /var/www/discourse/public/backups/default/${LATEST_BACKUP}"
docker exec -i ${CONTAINER_NAME} sh -x << EOF
discourse enable_restore
rails runner "SiteSetting.set('backup_location', 'local')"
discourse restore ${LATEST_BACKUP}
discourse disable_restore
rm -f /var/www/discourse/public/backups/default/${LATEST_BACKUP}
EOF
# Container neu erstellen
cd /var/lib/discourse/discourse_docker
stdbuf -oL -eL ./launcher rebuild ${CONTAINER_NAME} 2>&1 | sed 's/DISCOURSE_google_oauth2_client_secret=[^ ]*/DISCOURSE_google_oauth2_client_secret=***REDACTED***/g'
cd -
rm -f /tmp/${LATEST_BACKUP}
Das rails runner \"SiteSetting.set('backup_location', 'local')\" fehlte und verhinderte die Wiederherstellung aus dem Backup-Tarball.
Beachten Sie, dass die Ausgabe des Launcher-Skripts redigiert werden musste, da sie Geheimnisse in ihrer Ausgabe preisgeben würde, insbesondere wenn sie über einen sichtbaren CI/CD-Job ausgeführt wird.