2017-07-22 13:14:20 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2017-11-20 22:59:01 +00:00
|
|
|
set -e
|
|
|
|
|
2017-11-11 10:35:43 +00:00
|
|
|
function check_railsserver_available {
|
|
|
|
until (echo > /dev/tcp/zammad-railsserver/3000) &> /dev/null; do
|
2017-11-26 20:25:57 +00:00
|
|
|
echo "waiting for railsserver to be ready..."
|
|
|
|
sleep 60
|
2017-11-11 10:35:43 +00:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
function zammad_backup {
|
|
|
|
TIMESTAMP="$(date +'%Y%m%d%H%M%S')"
|
2017-07-22 13:14:20 +00:00
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
echo "${TIMESTAMP} - backuping zammad..."
|
2017-07-22 13:14:20 +00:00
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
# delete old backups
|
2017-11-21 17:50:45 +00:00
|
|
|
if [ -d "${BACKUP_DIR}" ] && [ -n "$(ls ${BACKUP_DIR})" ]; then
|
|
|
|
find ${BACKUP_DIR}/*_zammad_*.gz -type f -mtime +${HOLD_DAYS} -exec rm {} \;
|
|
|
|
fi
|
2017-07-22 13:14:20 +00:00
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
# tar files
|
|
|
|
tar -czf ${BACKUP_DIR}/${TIMESTAMP}_zammad_files.tar.gz ${ZAMMAD_DIR}
|
2017-07-22 13:14:20 +00:00
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
#db backup
|
|
|
|
pg_dump --dbname=postgresql://postgres@zammad-postgresql:5432/zammad_production | gzip > ${BACKUP_DIR}/${TIMESTAMP}_zammad_db.psql.gz
|
2017-10-24 21:17:40 +00:00
|
|
|
}
|
|
|
|
|
2017-10-28 11:50:18 +00:00
|
|
|
if [ "$1" = 'zammad-backup' ]; then
|
|
|
|
|
|
|
|
check_railsserver_available
|
2017-10-24 21:17:40 +00:00
|
|
|
|
|
|
|
while true; do
|
2017-11-11 10:34:18 +00:00
|
|
|
zammad_backup
|
2017-07-22 13:14:20 +00:00
|
|
|
|
|
|
|
# wait until next backup
|
|
|
|
sleep ${BACKUP_SLEEP}
|
|
|
|
done
|
|
|
|
fi
|
2017-10-24 20:50:44 +00:00
|
|
|
|
|
|
|
if [ "$1" = 'zammad-backup-once' ]; then
|
2017-10-28 11:50:18 +00:00
|
|
|
check_railsserver_available
|
2017-10-24 20:50:44 +00:00
|
|
|
|
2017-11-11 10:34:18 +00:00
|
|
|
zammad_backup
|
2017-10-24 20:50:44 +00:00
|
|
|
fi
|