应用场景
在一些应用中(比如Jenkins),嵌入了shell脚本,系统通过shell脚本的返回值来判断执行结果,如果返回值非0,则发生了执行错误,需要中止执行,这在使用单个命令时没有问题。然而,在shell (A)脚本又调用了shell脚本文件(B )时,当被调用的shell脚本B执行过程中发生了错误时,系统不会认为B有问题,而是继续往下执行。这样就会掩盖了问题。
解决
在被调用的shell脚本B中返回错误代码,当被调用的shell脚本B中发生错误时,捕捉该错误代码,然后返回该错误代码,这样系统就能捕获被调用的脚本B的错误代码,而及时中止执行。
1、实现步骤:
(2)加入执行执行结果代码检测函数,若发现结果代码非0,则返回脚本的执行代码。使用“exit [代码]”表示。
2、示例:
Shell A:
#do something ... /home/test/B.sh #do something ...
Shell B(/home/test/B.sh):
check_result() { echo input params:$1 if [ $1 != 0 ]; then echo wahaha exit $1 fi } ls / echo 1.result:$? check_result $? cat /xxxyyy v1=$? echo 2.result:{v1} check_result $v1check_result()为定义的检测函数,当命令的返回码非0时,shell脚本停止执行,返回代码。
v1=$? 保存命令执行返回码,其为临时变量。需要保存留作后用。
附录:
@H_403_29@1、shell 返回码 参考:Linux Shell Bash 带有特殊含义的退出码表格 D-1."保留的"退出码
@H_404_38@1
2
126
127
$PATH
不对,或者是拼写错误128
128+n
$PPID
130
255*
shell返回码,标识整个脚本的执行结果状态,用“exit 返回码”表示。