2018-10-03 20:27:03 -05:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
|
|
#Script to back up /home/tracey to external USB drive
|
|
|
|
|
#http://www.bobulous.org.uk/misc/rsync-backup.html
|
|
|
|
|
date=`date +%Y-%m-%d`
|
2019-01-05 12:45:29 -06:00
|
|
|
log_file='/home/tracey/backuplogs/usb-rsync-backup-'${date}'.txt'
|
2018-10-03 20:27:03 -05:00
|
|
|
|
|
|
|
|
echo "#####"
|
|
|
|
|
echo ""
|
2020-03-14 21:02:44 -05:00
|
|
|
|
|
|
|
|
# Check what OS we're on
|
|
|
|
|
# OS=`awk -F = '/NAME/{print $2}' /etc/os-release`
|
|
|
|
|
# echo "OS we're running on is $OS"
|
|
|
|
|
source ~/git/shell-scripts/check_os.sh
|
|
|
|
|
|
2020-10-14 21:36:44 -05:00
|
|
|
# Get the mount point by uuid - for old USB drive
|
|
|
|
|
#UUID=ff0b3c83-853d-452f-abb6-48069e337446
|
|
|
|
|
#mount_point=`findmnt -rn -S UUID=$UUID -o TARGET`
|
|
|
|
|
|
|
|
|
|
# For dedicated Linux Backup drive
|
|
|
|
|
# LABEL="LinuxBack" UUID="af60e100-e805-4318-abc8-175f916ff18a" TYPE="ext4" PARTUUID="3b3d0d2d-65a8-e440-a878-29fbf9184759"
|
|
|
|
|
|
|
|
|
|
mount_point=/data/LinuxBack
|
2020-06-07 13:22:23 -05:00
|
|
|
|
2020-03-14 21:02:44 -05:00
|
|
|
echo "Mount point is $mount_point"
|
|
|
|
|
|
2018-10-03 20:27:03 -05:00
|
|
|
# Check whether target volume is mounted, and mount it if not.
|
|
|
|
|
if ! mountpoint -q ${mount_point}/; then
|
|
|
|
|
echo "Mounting the external USB drive."
|
|
|
|
|
echo "Mountpoint is ${mount_point}"
|
|
|
|
|
if ! mount ${mount_point}; then
|
|
|
|
|
echo "An error code was returned by mount command!"
|
|
|
|
|
exit 5
|
|
|
|
|
else echo "Mounted successfully.";
|
|
|
|
|
fi
|
|
|
|
|
else echo "${mount_point} is already mounted.";
|
|
|
|
|
fi
|
|
|
|
|
# Target volume **must** be mounted by this point. If not, die screaming.
|
|
|
|
|
if ! mountpoint -q ${mount_point}/; then
|
2020-06-07 13:22:23 -05:00
|
|
|
echo "Mounting failed! Cannot run backup without mounted backup volume!"
|
2018-10-03 20:27:03 -05:00
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
2020-06-07 14:20:10 -05:00
|
|
|
echo "Preparing to rsync differences in home directory to backup USB drive."
|
2018-10-03 20:27:03 -05:00
|
|
|
|
2020-10-14 18:55:39 -05:00
|
|
|
rsync -azh --exclude '.cache' --exclude 'Videos' --exclude 'Nextcloud' --exclude 'Downloads/isos' --exclude 'VirtualBox VMs' --exclude 'Sync' --exclude '.local/share/Steam' --exclude 'Music' --exclude '.Trash-*' --exclude 'home_backup' --progress /home/tracey/ $mount_point/tracey_home --delete 2>&1 | tee $log_file
|
2018-10-03 20:27:03 -05:00
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
|
echo "Backup Complete"
|
2018-10-03 20:29:13 -05:00
|
|
|
echo "Log of this backup is in $log_file"
|
2019-01-04 18:18:00 -06:00
|
|
|
echo "Now deleting backup logs over 7 days"
|
2018-10-03 20:27:03 -05:00
|
|
|
echo "####"
|
2019-01-04 18:18:00 -06:00
|
|
|
|
2019-01-05 12:45:29 -06:00
|
|
|
find /home/tracey/backuplogs -iname 'usb-rsync-backup-*' -mtime +7 -type f -delete
|