在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
应用场景 在一些应用中(比如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 $v1 check_result()为定义的检测函数,当命令的返回码非0时,shell脚本停止执行,返回代码。 附录: 1、shell 返回码 表格 D-1. "保留的"退出码
2、shell返回码与函数返回码、命令返回码的区别
到此这篇关于shell脚本返回值及其使用场景的实现的文章就介绍到这了,更多相关shell脚本返回值内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论