shell脚本返回值及其使用场景的实现
                (编辑:jimmy 日期: 2025/11/4 浏览:3 次 )
            
            应用场景
在一些应用中(比如Jenkins),嵌入了shell脚本,系统通过shell脚本的返回值来判断执行结果,如果返回值非0,则发生了执行错误,需要中止执行,这在使用单个命令时没有问题。然而,在shell (A)脚本又调用了shell脚本文件(B )时,当被调用的shell脚本B执行过程中发生了错误时,系统不会认为B有问题,而是继续往下执行。这样就会掩盖了问题。
解决
在被调用的shell脚本B中返回错误代码,当被调用的shell脚本B中发生错误时,捕捉该错误代码,然后返回该错误代码,这样系统就能捕获被调用的脚本B的错误代码,而及时中止执行。
1、实现步骤:
(1)获取执行结果代码。使用“$"htmlcode">
#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:$"color: #ff0000">附录:
1、shell 返回码
表格 D-1. "保留的"退出码
  
 
  
    
      退出码的值 
      含义 
      例子 
      注释 
    
  
  
    
      1
      通用错误
      let "var1 = 1/0"
      各种各样的错误都可能使用这个退出码, 比如"除0错误"
    
    
      2
      shell内建命令使用错误(Bash文档上有说明)
      
      很少看到, 通常情况下退出码都为1
    
    
      126
      命令调用不能执行
      
      程序或命令的权限是不可执行的
    
    
      127
      "command not found"
      
      估计是$PATH不对, 或者是拼写错误
    
    
      128
      exit的参数错误
      exit 3.14159
      exit只能以整数作为参数, 范围是0 - 255(见脚注)
    
    
      128+n
      信号"n"的致命错误
      kill -9 脚本的$PPID
      $"$"获取。
  
下一篇:linux shell 中判断文件、目录是否存在的方法