设为首页收藏本站language 语言切换
查看: 1146|回复: 0
收起左侧

Bash 脚本中的错误处理

[复制链接]
发表于 2022-9-7 03:20:36 | 显示全部楼层 |阅读模式
本文讲述了在 Bash 脚本中处理错误的一些技巧,如何获取错误代码、在执行脚本时获得详细输出、处理调试功能和错误重定向。使用这些技巧,系统管理员可以使他们的日常工作变得轻松。
退出状态

在 Bash 脚本中,$?将打印退出状态。如果返回零,则表示没有错误。如果不为零,结论就是任务可能存在一些问题。

如下是一个简单例子:

[root@localhost ~]# cat myscript.sh #!/bin/bashmkdir learningecho $?

如果运行上述脚本一次,它将打印 0,因为该目录不存在,因此脚本将创建它。如果第二次运行该脚本,将获得一个非零值,如下所示:

[root@localhost ~]# sh myscript.sh 0[root@localhost ~]# sh myscript.sh mkdir: cannot create directory ‘learning’: File exists1


                               
登录/注册后可看大图

最佳实践

建议通过将 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 testingtest3.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 -xa=2b=3c=$(( $a + $b ))DEBUG set +x

输出内容如下:

[root@localhost ~]# sh debug.sh Testing Debugging+ a=2+ b=3+ c=5+ DEBUG set +x+ '[' on == on ']'+ set +x2 + 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/bashPS4='$LINENO: 'set -xecho "Hello World!"mkdiir testing

可以在阅读错误时轻松查看行号:

[root@localhost ~]# sh test3.sh 5: echo 'Hello World!'Hello World!6: mkdiir testingtest3.sh: line 6: mkdiir: command not found


                               
登录/注册后可看大图

总结

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

https://www.51cto.com/it/news/2022/0905/34207.html

https://www.51cto.com/it/news/2022/0905/34208.html

https://www.csdn.net/article/2022-09-06/126720771


您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2025-2-2 20:42 , Processed in 0.072224 second(s), 11 queries , Redis On.  

  Powered by Discuz!

  © 2001-2025 HH010.COM

快速回复 返回顶部 返回列表