Mercurial > public > ssdt-docker
view scripts/restore-itcm.sh @ 525:c941bcc97e5b
flow: Merged <hotfix> '2.16.1' to <develop> ('default').
author | Marc Davis <marc.davis@mcoecn.org> |
---|---|
date | Tue, 30 Jan 2024 10:55:15 -0500 |
parents | c059e112e719 |
children | 6f7ae8d659cf |
line wrap: on
line source
#!/bin/bash source "${SSDT_SCRIPTS:-$(dirname "${BASH_SOURCE[0]}")}/.functions.sh" sourceFile=${1?must provide backup file to be restored} if [ -z "$1" ] then echo "Usage: `basename $0` {backup file to restore}" echo " must specify the name of the file to restore. Assumed to be in format:" echo " {entityId}-itcm-db.{timestamp}.backup.gz " exit $E_NOARGS fi function prop { grep "${1}" .env/itcm-shared.properties|cut -d'=' -f2 } entityId=$(prop 'entityId' | tr -d '"') dbContainerName="$entityId-itcm-db" appContainerName="$entityId-itcm-app" target="itcmdb" echo echo "Preparing to restore" echo "--------------------" echo " file: $sourceFile" echo " to $dbContainerName database: $target" echo " " echo "WARNING: This operation will DELETE and replace any exising database" echo " " read -e -p "Continue? <y/N> " answer case $answer in y | Y | yes | YES ) answer="y";; n | N | no | NO ) answer="n";; *) answer="n" esac if [ "$answer" == "y" ] then echo "stopping application service $appContainerName" docker stop $appContainerName echo "copy backup file to database container" docker cp ${sourceFile} ${dbContainerName}:/tmp/restore.backup.gz echo "starting database restore" docker exec -t -u postgres $dbContainerName sh -c "gunzip -f /tmp/restore.backup.gz -c | psql" fi