remote_fs=$2
remote_pool=${2%%/*}
+# get the backup pool from the command line or the config file if not specified
+if [[ -n $3 ]]; then
+ backup_pool=$3
+else
+ backup_pool=${backup_pool%% *} # use the first backup pool if none specified
+fi
+
# Setup our cleanup and exit trap
cleanup() {
if [[ -e "$local_list" ]]; then
fatal_and_exit "-E- remote incremental $zfs rollback command failed on $hostname" $mailto
fi
# Now it should be safe to send the snaps
- replicate "$zfs send -R -I${previous_backup_marker} ${current_backup_marker}"
+ replicate "$zfs send -Rc -I${previous_backup_marker} ${current_backup_marker}"
if [ $? != 0 ]; then
fatal_and_exit "-E- remote incremental $zfs send command failed on $hostname" $mailto
fi
if [[ -n "$common" ]]; then
# We found a common snapshot, incrementally send the new snaps
- replicate "$zfs send -R -I${common/*@/@} ${current_backup_marker}"
+ replicate "$zfs send -Rc -I${common/*@/@} ${current_backup_marker}"
if [ $? != 0 ]; then
fatal_and_exit "-E- remote incremental $zfs send command failed on $hostname" $mailto
fi
fi
fi
# Send the full filesystem
- replicate "$zfs send -R ${current_backup_marker}"
+ replicate "$zfs send -Rc ${current_backup_marker}"
if [ $? != 0 ]; then
fatal_and_exit "-E- remote full $zfs send command failed on $hostname" $mailto
fi