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.
|
# 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)"
|
NAS_DEVICE_NAME="Hetzner Storagebox (Alpha)"
|
||||||
RCHAT_NOTIFIER="${HOME}/repos/utilities/rocketchat_notifier.sh"
|
RCHAT_NOTIFIER="${HOME}/repos/utilities/rocketchat_notifier.sh"
|
||||||
SOURCE_MOUNTPOINT="/media/hetzner-storagebox-alpha"
|
SOURCE_MOUNTPOINT="/media/hetzner-storagebox-alpha"
|
||||||
|
@ -67,7 +62,7 @@ fi
|
||||||
|
|
||||||
echo "INFO Beginning backup."
|
echo "INFO Beginning backup."
|
||||||
|
|
||||||
sudo rsync -rtv --progress --delete --no-perms \
|
sudo rsync -avzP --delete --no-perms \
|
||||||
--exclude="*.lock" \
|
--exclude="*.lock" \
|
||||||
--exclude="*.bleve/store/root.bolt" \
|
--exclude="*.bleve/store/root.bolt" \
|
||||||
--exclude="mongo/db/mongod.lock" \
|
--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