shell脚本返回值及其使用场景
应用场景在一些应用中(比如Jenkins),嵌入了shell脚本,系统通过shell脚本的返回值来判断执行结果,如果返回值非0,则发生了执行错误,需要中止执行,这在使用单个命令时没有问题。然而,在shell (A)脚本又调用了shell脚本文件(B )时,当被调用的shell脚本B执行过程中发生了错误时,系统不会认为B有问题,而是继续往下执行。这样就会掩盖了问题。 解决在被调用的shell脚本B中返回错误代码,当被调用的shell脚本B中发生错误时,捕捉该错误代码,然后返回该错误代码,这样系统就能捕获被调用的脚本B的错误代码,而及时中止执行。 1、实现步骤: (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=$? 保存命令执行返回码,其为临时变量。需要保存留作后用。 附录:1、shell 返回码参考:Linux Shell Bash 带有特殊含义的退出码表格 D-1."保留的"退出码
2、shell返回码与函数返回码、命令返回码的区别shell返回码,标识整个脚本的执行结果状态,用“exit 返回码”表示。 函数返回码,标识一个函数的执行结果状态,用“return 返回码”表示。 命令返回码,标识一个命令的执行结果状态,在命令执行后,紧跟着获取返回码,用"$?"获取。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |