
shell 是用户和操作系统交互的一个程序,经常用于执行一些自动化或者重复繁琐的任务,现在所有的 Linux 系统基本都自带了该程序,我们只需要编写好shell脚本,直接执行就可以了,不需要额外安装软件、配置编译环境,可以说使用起来非常的方便,但是它在调试方面常常令人头大,本文主要介绍shell脚本常用的调试方法
调试常用选项
调试shell脚本时,常常用到几个调试选项,让脚本在执行的过程中,会输出一些调试信息,根据调试信息,就可以定位出具体出问题的代码
具体的选项以及说明如下:
| 选项 | 说明 |
|---|---|
| -x | 输出结果之前,先输出执行的命令 |
| -u | 遇到不存在的变量就会报错,并停止执行 |
| -e | 发生错误时,终止执行 |
| -n | 检查语法错误 |
| -o pipefail | 管道子命令发生错误,终止执行 |
跟踪脚本的执行
- 输出调试信息
通常,脚本执行之后,只有结果输出,当运行多条命令的时候,就会连续输出多条结果,无法分清哪条命令对应哪条结果, 使用 -x选项,会先输出将要执行的那一行命令的调试信息,然后再执行命令
现有脚本ta.sh,功能是输出当前日期, 内容如下
#!/bin/bash
echo "today is :"$(date +'%Y-%m-%d')
我们使用 -x选项来执行脚本,结果如下
[root@VM-0-2-centos shell_debug]# bash -x ta.sh
++ date +%Y-%m-%d
+ echo 'today is :2021-07-10'
today is :2021-07-10
从结果中可以看到,在执行前打印出了每一行命令,行前面的 + 号表示调试信息,它实际是环境变量 PS4 的值, PS4 的第一个字符会根据嵌套层次进行重复,命令所处的层次越深,前面的 + 号越多
结果中第一行表示执行 date +'%Y-%m-%d'命令,它处于第内层,所以打印两个 + 号 ,第二行表示执行 echo "today is :"$(date +&#

本文介绍了Bash脚本的调试方法,包括调试常用选项、跟踪脚本执行、日志打印和常见错误处理。通过设置选项如-x和-e,以及使用_PS4变量,可以有效地定位和解决脚本中的错误。此外,还讲解了如何通过日志开关控制调试信息的输出,以及处理不存在的变量、语法错误和其他错误情况。
最低0.47元/天 解锁文章
597

被折叠的 条评论
为什么被折叠?



