您可以通过使用“&&”继续执行一系列命令直到“失败”连续运行命令;每个命令返回“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
(免责声明……上面显示的命令是一般的伪代码,只是从内存中输入而不运行它们.Typos肯定存在.)