Compare commits
3 commits
342178ed8f
...
0c160a710d
Author | SHA1 | Date | |
---|---|---|---|
0c160a710d | |||
904962c83c | |||
![]() |
a4fe799e30 |
3 changed files with 76 additions and 6 deletions
24
copy_forgejo_db_backup.sh
Executable file
24
copy_forgejo_db_backup.sh
Executable 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
|
|
@ -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
51
vps_mysql_backup.sh
Executable 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
|
Loading…
Add table
Reference in a new issue