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的整数作为参数
2、shell返回码与函数返回码、命令返回码的区别
shell返回码,标识整个脚本的执⾏结果状态,⽤“exit 返回码”表⽰。
函数返回码,标识⼀个函数的执⾏结果状态,⽤“return 返回码”表⽰。
命令返回码,标识⼀个命令的执⾏结果状态,在命令执⾏后,紧跟着获取返回码,⽤"$?"获取。


发布评论