2023年11月27日发(作者:)

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/

#do something ...

126命令调⽤不能执⾏ 程序或命令的权限是不可执⾏的

退出码的值含义例⼦注释

127"command not found" 估计是$PATH不对, 或者是拼写错误

128的参数错误exit 3.14159exit只能以整数作为参数, 范围是0 - 255(见脚注)

128+n信号"n"的致命错误kill -9 脚本的$PPID$? 返回137(128 + 9)

130⽤Control-C来结束脚本 Control-C是信号2的致命错误, (130 = 128 + 2, 见上边)

255*超出范围的退出状态exit -1exit命令只能够接受范围是0 - 255的整数作为参数

2shell返回码与函数返回码、命令返回码的区别

shell返回码,标识整个脚本的执⾏结果状态,⽤“exit 返回码”表⽰。

函数返回码,标识⼀个函数的执⾏结果状态,⽤“return 返回码”表⽰。

命令返回码,标识⼀个命令的执⾏结果状态,在命令执⾏后,紧跟着获取返回码,⽤"$?"获取。