diff --git a/src/zfs-auto-snapshot.8 b/src/zfs-auto-snapshot.8 index f98c958..c8ae42b 100644 --- a/src/zfs-auto-snapshot.8 +++ b/src/zfs-auto-snapshot.8 @@ -46,10 +46,10 @@ PRE is 'zfs\-auto\-snap' by default. \fB\-q\fR, \fB\-\-quiet\fR Suppress warnings and notices at the console. .TP -\fB\-\-send\-full\fR=[\fIremote host\fR]:[\fIremote pool\fR] +\fB\-\-send\-full\fR=[\fIremote host\fR]:[\fIremote pool\fR][;...] Send zfs full backup to remote hostname (or IP address) and put it in remote pool. .TP -\fB\-\-send\-incr\fR=[\fIremote host\fR]:[\fIremote pool\fR] +\fB\-\-send\-incr\fR=[\fIremote host\fR]:[\fIremote pool\fR][;...] Send zfs incremental backup to remote hostname (or IP address) and put it in remote pool. .TP \fB\-\-send\-fallback\fR diff --git a/src/zfs-auto-snapshot.sh b/src/zfs-auto-snapshot.sh index cf980c0..7f624af 100755 --- a/src/zfs-auto-snapshot.sh +++ b/src/zfs-auto-snapshot.sh @@ -35,8 +35,7 @@ opt_label='' opt_prefix='zfs-auto-snap' opt_recursive='' opt_send_type='' -opt_send_host='' -opt_recv_pool='' +opt_send='' opt_send_opts='' opt_recv_opts='' opt_send_ssh_opts='' @@ -188,7 +187,7 @@ do_snapshots () # properties, flags, snapname, oldglob, [targets...] if [ $RUNSNAP -eq 1 ] && do_run "zfs snapshot $PROPS $FLAGS '$ii@$NAME'" then [ "$opt_post_snapshot" != "" ] && do_run "$opt_post_snapshot $ii $NAME" - [ -n "$opt_send_host" ] && SNAPS_DONE="$SNAPS_DONE + [ -n "$opt_send" ] && SNAPS_DONE="$SNAPS_DONE $ii@$NAME" SNAPSHOT_COUNT=$(( $SNAPSHOT_COUNT + 1 )) else @@ -228,13 +227,13 @@ do_send () # snapname, oldglob local NAME="$1" local GLOB="$2" local RUNSEND=1 - local remote + local remote_ssh="ssh $opt_send_ssh_opts" + local remote_recv="zfs receive $opt_recv_opts" + local remote_mbuf="" local ii local jj - [ -n "$opt_send_mbuf_opts" ] && remote="mbuffer $opt_send_mbuf_opts |" - remote="$remote ssh $opt_send_ssh_opts $opt_send_host" - remote="$remote zfs receive $opt_recv_opts" + [ -n "$opt_send_mbuf_opts" ] && remote_mbuf="mbuffer $opt_send_mbuf_opts |" # STEP 1: Go throug all snapshots we've created for ii in $SNAPS_DONE @@ -309,17 +308,34 @@ $jj" fi if [ $RUNSEND -eq 1 ]; then - if [ "$opt_send_type" = "incr" ]; then - if [ "$jj" = "$ii" -a -n "$opt_send_fallback" ]; then - do_run "zfs send $opt_send_opts -R $ii | $remote -F $opt_recv_pool" \ - || RUNSEND=0 + OLD_IFS=$IFS ; IFS=";" + + # Go through each option to --send-{incr,full}. + # rem=: + for rem in $opt_send; do + if [ "$opt_send_type" = "incr" ]; then + if [ "$jj" = "$ii" -a -n "$opt_send_fallback" ]; then + cmd="zfs send $opt_send_opts -R $ii |" + cmd="$cmd $remote_mbuf" + cmd="$cmd $remote_ssh ${rem%:*}" + cmd="$cmd $remote_recv -F ${rem#*:}" + else + cmd="zfs send $opt_send_opts -i $jj $ii |" + cmd="$cmd $remote_mbuf" + cmd="$cmd $remote_ssh ${rem%:*}" + cmd="$cmd $remote_recv ${rem#*:}" + fi else - do_run "zfs send $opt_send_opts -i $jj $ii | $remote $opt_recv_pool" \ - || RUNSEND=0 + cmd="zfs send $opt_send_opts -R $jj |" + cmd="$cmd $remote_mbuf" + cmd="$cmd $remote_ssh ${rem%:*}" + cmd="$cmd $remote_recv ${rem#*:}" fi - else - do_run "zfs send $opt_send_opts -R $jj | $remote $opt_recv_pool" || RUNSEND=0 - fi + + do_run "$cmd" || RUNSEND=0 + done + + IFS=$OLD_IFS if [ $RUNSEND = 1 -a -n "$opt_post_send" ]; then do_run "$opt_post_send $jj" || RUNSEND=0 @@ -426,18 +442,13 @@ do ;; (--send-full) opt_send_type='full' - - opt_send_host=$(echo "$2" | sed 's,:.*,,') - opt_recv_pool=$(echo "$2" | sed 's,.*:,,') - opt_send_opts="$opt_send_opts -R" + opt_send="$2" shift 2 ;; (--send-incr) opt_send_type='incr' - - opt_send_host=$(echo "$2" | sed 's,:.*,,') - opt_recv_pool=$(echo "$2" | sed 's,.*:,,') + opt_send="$2" shift 2 ;; (--send-fallback)