Voici le script fonctionnel que j’utilise pour restaurer la production vers le développement et les tests :
#!/bin/sh
set +x
set -e
# Ce script restaure la dernière sauvegarde productive vers l'environnement de test/développement
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
# s'assurer que /var/www/discourse/public/backups/default/ existe avec la bonne propriété
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
# reconstruire le conteneur
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}
Il manquait rails runner "SiteSetting.set('backup_location', 'local')" ce qui empêchait la restauration à partir de l’archive de sauvegarde.
Notez que la sortie du script du lanceur a dû être expurgée car elle divulguerait des secrets dans sa sortie, surtout lorsqu’elle est effectuée via un travail CI/CD visible.