Compare commits

..

3 commits

3 changed files with 76 additions and 6 deletions

24
copy_forgejo_db_backup.sh Executable file
View file

@ -0,0 +1,24 @@
#!/bin/bash
# Copy backup of Forgejo database on VPS to local device
LOCAL_MOUNTPOINT="/media/my-passport"
RCHAT_NOTIFIER="${HOME}/repos/utilities/rocketchat_notifier.sh"
mountpoint -q ${LOCAL_MOUNTPOINT}
if [ $? -eq 1 ]; then
$RCHAT_NOTIFIER "backups" "error" \
"Could not transfer Forgejo DB backup from VPS. Local backup disk (/media/my-passport) not mounted."
exit
fi
scp 'thomas@systemsobscure.net:/home/thomas/backups/forgejo/*.sql.gz' "${LOCAL_MOUNTPOINT}/vps_backups/mysql/forgejo/"
if [ $? -eq 0 ]; then
BACKUP_FILE=$(ls -t "${LOCAL_MOUNTPOINT}/vps_backups/mysql/forgejo" | head -1)
$RCHAT_NOTIFIER "backups" "success" "Copied Forgejo DB backup from VPS. File: ${BACKUP_FILE}"
else
$RCHAT_NOTIFIER "backups" "error" \
"Could not transfer Forgejo DB backup from VPS."
fi

View file

@ -2,11 +2,6 @@
# Backup Hetzner Storagebox (Alpha) used by VPS for service data.
# USER=thomas
# export HOME=/home/thomas
# export XDG_RUNTIME_DIR=/run/user/1000
# source /home/thomas/.env
NAS_DEVICE_NAME="Hetzner Storagebox (Alpha)"
RCHAT_NOTIFIER="${HOME}/repos/utilities/rocketchat_notifier.sh"
SOURCE_MOUNTPOINT="/media/hetzner-storagebox-alpha"
@ -67,7 +62,7 @@ fi
echo "INFO Beginning backup."
sudo rsync -rtv --progress --delete --no-perms \
sudo rsync -avzP --delete --no-perms \
--exclude="*.lock" \
--exclude="*.bleve/store/root.bolt" \
--exclude="mongo/db/mongod.lock" \

51
vps_mysql_backup.sh Executable file
View file

@ -0,0 +1,51 @@
#!/bin/bash
# Backup MYSQL dir on VPS
RCHAT_NOTIFIER="${HOME}/repos/utilities/rocketchat_notifier.sh"
TARGET_NAME="VPS: /data/mysql"
LOCAL_DISK_MOUNTPOINT="/media/my-passport"
LOCAL_DIR="${LOCAL_DISK_MOUNTPOINT}/vps_backups/mysql"
# function clean_up() {
# # Dismount NAS
# echo "INFO Dismounting ${NAS_DEVICE_NAME}."
# sudo umount /media/hetzner-storagebox-alpha/
# # Turn on VPN
# echo "INFO Re-connecting Mullvad VPN."
# mullvad connect
# exit
# }
# Check source disk is mounted
if mountpoint -q ${LOCAL_DISK_MOUNTPOINT}; then
echo "INFO Local disk /media/my-passport mounted. Proceeding."
else
echo "INFO Local disk not mounted. Mounting /media/my-passport."
sudo mount ${LOCAL_DISK_MOUNTPOINT}
if mountpoint -q ${LOCAL_MOUNTPOINT}; then
echo "INFO Mounted /media/my-passport"
else
$RCHAT_NOTIFIER "backups" "error" \
"Could not complete scheduled backup of ${TARGET_NAME}. Local backup disk (/media/my-passport) not mounted."
clean_up
fi
fi
rsync -avzP --delete \
thomas@systemsobcure.net:/data/mysql "${LOCAL_DIR}"
STATUS=$?
if [ $STATUS -eq 0 ]; then
$RCHAT_NOTIFIER "backups" "success" \
"Created backup of ${TARGET_NAME}."
# 23 = partial backup, 24 = some vanished files, both != major failure
elif [ $STATUS -eq 23 ] || [ $STATUS -eq 24 ]; then
$RCHAT_NOTIFIER "backups" "success" \
"Created backup of ${TARGET_NAME}. A few files could not be copied."
else
$RCHAT_NOTIFIER "backups" "error" \
"Failed to create backup of ${TARGET_NAME}: problem with rsync (exit code $STATUS)."
fi