分享工作和学习中的点点滴滴,包括前端、后端、运维、产品等各个方面,欢迎您来关注订阅!
(481)
(26)
(97)
(119)
(153)
(70)
(16)
分类: linux
2022-09-07 03:20:13
本文讲述了在 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 添加到 脚本来启用调试模式,如下所示:
[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
输出内容如下:
[root@localhost ~]# sh debug.sh 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 脚本中处理错误的一些技巧,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向。使用这些技巧,系统管理员可以使他们的日常工作变得轻松。
上一篇:
下一篇: