scripts/zfsync.sh

79 lines
2.6 KiB
Bash
Raw Normal View History

#!/bin/sh
# zfsync: sync zfs pool(s) between two servers
# in case of failure, unexpected reboot while syncing, etc.:
#
# launch "zfsync.sh init"
#
# or manually:
#
2023-08-10 21:47:21 +02:00
# - destroy all snapshots on both local & $bro
2014-09-28 21:55:24 +02:00
# - for i in ftp web mail; do zfs snapshot servers/$i/home@newsync ;done
2023-08-10 21:47:21 +02:00
# - for i in ftp web mail; do zfs send servers/$i/home@newsync | ssh "$bro" zfs receive -vFd servers ;done
# - for i in ftp web mail; do zfs rename servers/$i/home@newsync servers/$i/home@prevsync ;done
2023-08-10 21:47:21 +02:00
# - ssh "$bro" 'for i in ftp web mail; do zfs rename servers/$i/home@newsync servers/$i/home@prevsync ;done'
2023-08-10 21:47:21 +02:00
bro="{{ bro }}"
pools="ftp mail web"
2023-08-10 21:47:21 +02:00
SENDZABBIX="zabbix_sender --config /usr/local/etc/zabbix6/zabbix_agentd.conf --key check.zfsync"
HOSTNAME=$(/bin/hostname -f | /usr/bin/cut -d '.' -f 1,1)
LOCKFILE=/tmp/zfsync.lock
ZROOT=zdata/servers
2023-08-10 21:47:21 +02:00
echo "$(date): ZFSync starting."
if [ -e "$LOCKFILE" ]
then
2023-08-10 21:47:21 +02:00
echo "ERROR: $0 is already running with pid $(cat $LOCKFILE), check $LOCKFILE"
exit 1
fi
echo ${$}>$LOCKFILE
alert()
{
2023-08-10 21:47:21 +02:00
${SENDZABBIX} --value 1 >/dev/null
exit $?
}
2023-08-10 21:47:21 +02:00
if [ "$1" ]
then
2023-08-10 21:47:21 +02:00
if [ "$1" = "init" ]
then
echo "wiping previous syncs"
2023-08-10 21:47:21 +02:00
for snapshot in $(zfs list -t snapshot -o name | grep -e prevsync -e newsync); do zfs destroy "$snapshot" ; done
ssh -q "$bro" 'for snapshot in $(zfs list -t snapshot -o name | grep -e prevsync -e newsync); do zfs destroy $snapshot ; done'
echo "making full snapshots"
2023-08-10 21:47:21 +02:00
for jail in $pools; do zfs snapshot "$ZROOT/$jail/home@newsync";done
echo "sending full snapshots"
2023-08-10 21:47:21 +02:00
for jail in $pools; do zfs send "$ZROOT/$jail/home@newsync" | ssh -q "$bro" 'zfs receive -vFdu zdata' ;done
echo "renaming them to use them as a base for diff snapshots"
2023-08-10 21:47:21 +02:00
for jail in $pools; do zfs rename "$ZROOT/$jail/home@newsync" "$ZROOT/$jail/home@prevsync" ;done
ssh -q "$bro" 'for jail in ftp mail web; do zfs rename zdata/servers/$jail/home@newsync zdata/servers/$jail/home@prevsync ;done'
exit $?
fi
fi
for pool in $pools
do
dataset="$ZROOT/${pool}/home"
echo "making new snapshot for ${pool}"
2023-08-10 21:47:21 +02:00
zfs snapshot "${dataset}@newsync" || alert
echo "sending snapshot"
2023-08-10 21:47:21 +02:00
ssh -q "$bro" "zfs set readonly=on ${dataset}" || alert
sleep 2
zfs send -i @prevsync "${dataset}@newsync" | ssh -q "$bro" "zfs receive -vFdu zdata" || alert
ssh -q "$bro" "zfs set readonly=off ${dataset}" || alert
echo "cleaning"
2023-08-10 21:47:21 +02:00
zfs destroy "${dataset}@prevsync" || alert
zfs rename "${dataset}@newsync" "${dataset}@prevsync" || alert
ssh -q "$bro" "zfs destroy ${dataset}@prevsync && zfs rename ${dataset}@newsync ${dataset}@prevsync" || alert
done
echo
2023-08-10 21:47:21 +02:00
${SENDZABBIX} --value 0 >/dev/null
rm -f $LOCKFILE
2023-08-10 21:47:21 +02:00
echo "$(date): ZFSync ending."