mirror of
https://github.com/garraflavatra/docker-volume-s3-backup.git
synced 2025-05-17 05:14:37 +00:00
Add restore script
This commit is contained in:
parent
b462c54de6
commit
cc24a7d123
@ -22,6 +22,6 @@ ENV BACKUP_KEEP_DAYS ''
|
||||
ADD src/run.sh run.sh
|
||||
ADD src/env.sh env.sh
|
||||
ADD src/backup.sh backup.sh
|
||||
# ADD src/restore.sh restore.sh -- not ready yet
|
||||
ADD src/restore.sh restore.sh
|
||||
|
||||
CMD ["sh", "run.sh"]
|
||||
|
@ -8,18 +8,18 @@ source ./env.sh
|
||||
s3_uri_base="s3://${S3_BUCKET}/${S3_PREFIX}"
|
||||
|
||||
if [ -z "$PASSPHRASE" ]; then
|
||||
file_type=".dump"
|
||||
file_type=".tar.gz"
|
||||
else
|
||||
file_type=".dump.gpg"
|
||||
file_type=".tar.gz.gpg"
|
||||
fi
|
||||
|
||||
if [ $# -eq 1 ]; then
|
||||
timestamp="$1"
|
||||
key_suffix="${POSTGRES_DATABASE}_${timestamp}${file_type}"
|
||||
key_suffix="${BACKUP_NAME}_${timestamp}${file_type}"
|
||||
else
|
||||
echo "Finding latest backup..."
|
||||
key_suffix=$(
|
||||
aws $aws_args s3 ls "${s3_uri_base}/${POSTGRES_DATABASE}" \
|
||||
aws $aws_args s3 ls "${s3_uri_base}/${BACKUP_NAME}" \
|
||||
| sort \
|
||||
| tail -n 1 \
|
||||
| awk '{ print $4 }'
|
||||
@ -27,18 +27,16 @@ else
|
||||
fi
|
||||
|
||||
echo "Fetching backup from S3..."
|
||||
aws $aws_args s3 cp "${s3_uri_base}/${key_suffix}" "db${file_type}"
|
||||
aws $aws_args s3 cp "${s3_uri_base}/${key_suffix}" "dump${file_type}"
|
||||
|
||||
if [ -n "$PASSPHRASE" ]; then
|
||||
echo "Decrypting backup..."
|
||||
gpg --decrypt --batch --passphrase "$PASSPHRASE" db.dump.gpg > db.dump
|
||||
rm db.dump.gpg
|
||||
gpg --decrypt --batch --passphrase "$PASSPHRASE" dump.tar.gz.gpg > dump.tar.gz
|
||||
rm dump.tar.gz.gpg
|
||||
fi
|
||||
|
||||
conn_opts="-h $POSTGRES_HOST -p $POSTGRES_PORT -U $POSTGRES_USER -d $POSTGRES_DATABASE"
|
||||
|
||||
echo "Restoring from backup..."
|
||||
pg_restore $conn_opts --clean --if-exists db.dump
|
||||
rm db.dump
|
||||
tar -xzf dump.tar.gz -C /data --strip-components 1
|
||||
rm dump.tar.gz
|
||||
|
||||
echo "Restore complete."
|
Loading…
x
Reference in New Issue
Block a user