这篇文章主要为大家分析了Bash脚本中处理错误的常用方法有哪些的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“Bash脚本中处理错误的常用方法有哪些”的知识吧。
下面小编将为大家分享一下在 Bash 脚本中处理错误的一些常用的方法,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向等,有需要的小伙伴可以参考一下。
在 Bash 脚本中,$?
将打印退出状态。如果返回零,则表示没有错误。如果不为零,结论就是任务可能存在一些问题。
如下是一个简单例子:
[root@localhost ~]# cat myscript.sh#!/bin/bashmkdir learningecho $?
如果运行上述脚本一次,它将打印 0,因为该目录不存在,因此脚本将创建它。如果第二次运行该脚本,将获得一个非零值,如下所示:
[root@localhost ~]# sh myscript.sh0 [root@localhost ~]# sh myscript.shmkdir: cannot create directory ‘learning’: File exists 1
建议通过将 set -x
命令添加到 shell 脚本来启用调试模式,如下所示:
[root@localhost ~]# cat test3.sh#!/bin/bashset -xecho "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
输出内容如下:
[root@localhost ~]# sh debug.shTesting 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.txtmkdir: cannot create directory ‘users’: File exists
大多数时候,很难在脚本中找到确切的行号。要打印带有错误的行号,请使用PS4
选项,其中的$LINENO
是预定义好的变量。
[root@localhost ~]# cat test3.sh#!/bin/bashPS4='$LINENO: 'set -xecho "Hello World!"mkdiir testing
可以在阅读错误时轻松查看行号:
[root@localhost ~]# sh test3.sh5: echo 'Hello World!'Hello World! 6: mkdiir testing test3.sh: line 6: mkdiir: command not found
关于“Bash脚本中处理错误的常用方法有哪些”就介绍到这了,更多相关内容可以搜索亿速云以前的文章,希望能够帮助大家答疑解惑,请多多支持亿速云网站!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。