共计 1440 个字符,预计需要花费 4 分钟才能阅读完成。
导读 | 本文讲述了在 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 |
最佳实践
建议通过将 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 |
可以编写如下调试函数,这有助于随时调用它,使用以下示例:
[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 |
输出内容如下:
[ | ]|
Testing Debugging | |
+ a=2 | |
+ b=3 | |
+ c=5 | |
+ DEBUG set +x | |
+ '[' on == on ']' | |
+ set +x | |
2 + 3 = 5 |
错误重定向
可以使用标准错误输出将所有系统错误重定向到自定义文件,标准错误可以用数字 2 表示。在 Bash shell 执行它,如下所示:
[root@localhost ~]# mkdir users 2> errors.txt | |
[root@localhost ~]# cat errors.txt | |
mkdir: cannot create directory‘users’: File exists |
大多数时候,很难在脚本中找到确切的行号。要打印带有错误的行号,请使用 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 脚本中处理错误的一些技巧,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向。使用这些技巧,系统管理员可以使他们的日常工作变得轻松。
正文完
星哥玩云-微信公众号
