Bash|Bash 脚本中的错误处理

本文讲述了在 Bash 脚本中处理错误的一些技巧,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向。使用这些技巧,系统管理员可以使他们的日常工作变得轻松。退出状态在 Bash 脚本中,$?将打印退出状态。如果返回零,则表示没有错误。如果不为零,结论就是任务可能存在一些问题。如下是一个简单例子:[root@localhost ~]# cat myscript.sh
!/bin/bash mkdir learning
echo $?
如果运行上述脚本一次,它将打印 0,因为该目录不存在,因此脚本将创建它。如果第二次运行该脚本,将获得一个非零值,如下所示:[root@localhost ~]# sh myscript.sh
0
[root@localhost ~]# sh myscript.sh
mkdir: cannot create directory ‘learning’: File exists
1
Bash|Bash 脚本中的错误处理
文章图片

最佳实践建议通过将 set -x 命令添加到 shell 脚本来启用调试模式,如下所示:[root@localhost ~]# cat test3.sh
!/bin/bash set -x
echo "Hello World!"
mkdiir testing
然后运行脚本查看:[root@localhost ~]# sh test3.sh

  • echo 'Hello World!'
    Hello World!
  • mkdiir testing
    test3.sh: line 4: mkdiir: command not found
Bash|Bash 脚本中的错误处理
文章图片

可以编写如下调试函数,这有助于随时调用它,使用以下示例:[root@localhost ~]# cat debug.sh
!/bin/bash _DEBUG="on"
function DEBUG()
{
[ "$_DEBUG" == "on" ] && $@
}
DEBUG echo 'Testing Debugging'
DEBUG set -x
a=2
b=3
c=$(( $a + $b ))
DEBUG set +x
输出内容如下:[root@localhost ~]# sh debug.sh
Testing Debugging
  • a=2
  • b=3
  • c=5
  • DEBUG set +x
  • '[' on == on ']'
  • set +x
    • 3 = 5
Bash|Bash 脚本中的错误处理
文章图片

错误重定向可以使用标准错误输出将所有系统错误重定向到自定义文件,标准错误可以用数字 2 表示。在 Bash shell 执行它,如下所示:[root@localhost ~]# mkdir users 2> errors.txt
[root@localhost ~]# cat errors.txt
mkdir: cannot create directory ‘users’: File exists
Bash|Bash 脚本中的错误处理
文章图片

大多数时候,很难在脚本中找到确切的行号。要打印带有错误的行号,请使用 PS4 选项,其中的$LINENO是预定义好的变量。[root@localhost ~]# cat test3.sh
!/bin/bash PS4='$LINENO: '
set -x
echo "Hello World!"
mkdiir testing
可以在阅读错误时轻松查看行号:[root@localhost ~]# sh test3.sh
5: echo 'Hello World!'
Hello World!
6: mkdiir testing
test3.sh: line 6: mkdiir: command not found
【Bash|Bash 脚本中的错误处理】Bash|Bash 脚本中的错误处理
文章图片

总结本文讲述了在 Bash 脚本中处理错误的一些技巧,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向。使用这些技巧,系统管理员可以使他们的日常工作变得轻松。

    推荐阅读