Compare commits
5 Commits
5be3d73987
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5edf742181 | ||
|
|
8e78938564 | ||
|
|
099ad06a81 | ||
|
|
5178dfd6e8 | ||
|
|
fb3f38d77d |
49
vmbackup.sh
49
vmbackup.sh
@@ -2,26 +2,40 @@
|
|||||||
|
|
||||||
set -e
|
set -e
|
||||||
set -u
|
set -u
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
retention=2
|
||||||
statusfile=/var/run/zabbix/vmbackup.status
|
statusfile=/var/run/zabbix/vmbackup.status
|
||||||
basedir=/mnt/backups/vms
|
basedir=/mnt/backups/vms
|
||||||
vbm="echo sudo -u cig vboxmanage"
|
vbm="sudo -u cig vboxmanage"
|
||||||
rsync="echo rsync"
|
rsync="rsync"
|
||||||
|
|
||||||
_exit () {
|
_exit () {
|
||||||
|
logger -p local1.info "$2 $1"
|
||||||
echo $1 > $statusfile
|
echo $1 > $statusfile
|
||||||
exit $1
|
exit $2
|
||||||
}
|
}
|
||||||
|
|
||||||
_mail () {
|
_mail () {
|
||||||
echo "$@" | mail -s "$(hostname -f) : vm backup error" root
|
echo "$@" | mail -s "$(hostname -f) : vm backup error" root
|
||||||
}
|
}
|
||||||
|
|
||||||
mount /mnt/backups &> /dev/null || _exit "mount failed"
|
function checkRunning {
|
||||||
|
local machine=$1
|
||||||
|
$vbm list runningvms | grep -q $machine
|
||||||
|
return $?
|
||||||
|
}
|
||||||
|
|
||||||
|
function _shutdown_vm {
|
||||||
|
net rpc shutdown -I 192.168.69.250 -U tom%123Soleil2022!
|
||||||
|
sleep 30
|
||||||
|
}
|
||||||
|
|
||||||
|
mount /mnt/backups &> /dev/null || _exit "mount failed" 2
|
||||||
|
|
||||||
if [ ! -d $basedir ] ; then
|
if [ ! -d $basedir ] ; then
|
||||||
_mail Dir $basedir not mounted
|
_mail Dir $basedir not mounted
|
||||||
_exit 41
|
_exit "no base dir" 41
|
||||||
fi
|
fi
|
||||||
|
|
||||||
outputdir=${basedir}/$(date -I)
|
outputdir=${basedir}/$(date -I)
|
||||||
@@ -29,33 +43,22 @@ outputdir=${basedir}/$(date -I)
|
|||||||
if [ $# -ne 1 ] ; then
|
if [ $# -ne 1 ] ; then
|
||||||
echo "Usage: $O vm"
|
echo "Usage: $O vm"
|
||||||
echo "Stop, backup and start given vm"
|
echo "Stop, backup and start given vm"
|
||||||
_exit 42
|
_exit "Usage" 42
|
||||||
fi
|
fi
|
||||||
|
|
||||||
function checkRunning {
|
|
||||||
local machine=$1
|
|
||||||
sudo -u cig vboxmanage list runningvms | grep -q $machine
|
|
||||||
return $?
|
|
||||||
}
|
|
||||||
|
|
||||||
machine=$1
|
machine=$1
|
||||||
if ( checkRunning $machine ) ; then
|
if ( checkRunning $machine ) ; then
|
||||||
mkdir -p ${outputdir}
|
mkdir -p ${outputdir}
|
||||||
cp -ar ${basedir}/current/. --target-directory=${outputdir}
|
_shutdown_vm
|
||||||
mv ${basedir}/current ${basedir}/old
|
$rsync --inplace --delete --delete-after -a /srv/VM/Win/roofline ${outputdir}/
|
||||||
ln -s ${outputdir} ${basedir}/current
|
|
||||||
test $? -eq 0 || { _mail "erreur de copie" ; _exit 44 ; }
|
|
||||||
$vbm controlvm $machine acpipowerbutton shutdown
|
|
||||||
sleep 60
|
|
||||||
$rsync --inplace -a /srv/VM/Win/roofline ${outputdir}/
|
|
||||||
ret=$?
|
ret=$?
|
||||||
test $ret -eq 0 || _mail "rsync error $ret"
|
test $ret -eq 0 || _mail "rsync error $ret"
|
||||||
$vbm startvm $machine
|
$vbm startvm $machine
|
||||||
ln -s ${outputdir} ${basedir}/current
|
test $ret -eq 0 && find ${basedir} -maxdepth 1 -type d -mtime +${retention} -exec echo rm -fr {} \;
|
||||||
test $ret -eq 0 && find ${basedir} -maxdepth 1 -type d -mtime +7 -exec echo rm -fr {} \;
|
|
||||||
umount /mnt/backups &> /dev/null || _mail "umount failed"
|
umount /mnt/backups &> /dev/null || _mail "umount failed"
|
||||||
_mail "backup done with status $ret"
|
_mail "backup done with status $ret"
|
||||||
_exit $ret
|
_exit "backup done" $ret
|
||||||
fi
|
fi
|
||||||
_mail "vm $machine not running"
|
_mail "vm $machine not running"
|
||||||
_exit 43
|
_exit "vm not running" 43
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user