解决方法
您可以通过使用“&&”继续执行一系列命令直到“失败”连续运行命令;每个命令返回“true”,导致以下命令运行.然后使用“||”在失败时运行命令,例如:
#!/bin/bash cp foo bar \ && mv bar bar{,.bak} \ && echo "good so far" \ && ls file123 | tee -a /tmp/msg.txt \ && mailx -u user -s "success" -f /tmp/msg.txt \ || mailx -u user -s "failure" -f ~/err.txt
因为那可能会变得混乱,所以使用函数,例如
#!/bin/bash do_work() { mv... || return 1 cp... || return 1 return 0 } report() { [ "$1" = "ok" ] && mailx .... [ "$1" != "ok" ] && mailx -s "$1" .... return 0 } do_work \ && report ok || report err
此外,继续上面的示例,您可以通过脚本中的“陷阱”添加一揽子规则,如果在脚本中的任何位置返回任何类型的错误状态(包括接收control-c(中断),它将始终执行某些命令) )脚本运行时发出信号):
#!/bin/bash tmp=/tmp/msg.$$.txt # Cleanup: delete tmp files on exit. On any error,trap and exit... then cleanup trap 'echo "cleaning up tmpfiles..." && rm $tmp >/dev/null 2>&1' 0 trap "exit 2" 1 2 3 15 ... do_work && exit 0