X-Git-Url: http://git.pippins.net/embedvideo/.git/static/git-logo.png?a=blobdiff_plain;f=zfs-replicate-all;h=6fc9bfc269014181bd655fba682c64314b1ace6c;hb=e258eefad11198b27f849e44bf560e4d508bb1f4;hp=8d43bd92430e3c1f5c0a124a50c08185c9803fa5;hpb=0b4e25e42e934ccd5258a5659ed15c394b7f0a62;p=zfs-ubuntu%2F.git diff --git a/zfs-replicate-all b/zfs-replicate-all index 8d43bd9..6fc9bfc 100755 --- a/zfs-replicate-all +++ b/zfs-replicate-all @@ -50,11 +50,15 @@ cleanup_and_exit() { } trap cleanup_and_exit INT -fatal_and_exit() { +fatal() { # echo message to terminal echo -e 2>&1 "$1" # send email notification - echo -e "$1" | $mailx -s "zfs scrub on $hostname failed" "$mailto" + echo -e "$1" | $mailx -s "zfs-replicate-all on $hostname failed" "$mailto" +} + +fatal_and_exit() { + fatal $* exit 1 } @@ -130,9 +134,14 @@ done # Export the local pool if told to do so if [[ $import_export_backup_pool == 1 ]]; then - zpool export $backup_pool + # Don't export the pool if there is a currently running zfs-scrub operation + ps -ef | grep "zfs-scrub" | grep -q "${backup_pool}" | grep -v grep if [ $? != 0 ]; then - fatal_and_exit "-E- unable to export the local backup pool $backup_pool on $hostname" "$mailto" + zpool export $backup_pool + if [ $? != 0 ]; then + lsof /$backup_pool/* + fatal("-E- unable to export the local backup pool $backup_pool on $hostname") + fi fi fi