1.11 调试脚本
- 调试功能是每一种编程语言都应该实现的重要特性之一,当出现一些始料未及的情况时,用它来生成脚本的运行信息,调试信息可以帮你弄清楚是什么原因使得程序发生崩溃或者行为异常。
1.11.1 Bash内建调试功能
- 使用Bash的内建调试功能,可以对整个脚本进行调试,也可以仅对脚本中的某些语句进行调试。
#!/bin/bash
for i in { 1 2 3 4 5 6 };
do
set -x
echo $i
set +x
done
echo "Script executed."
#使用 -x选项对整个脚本进行调试
bash -x script.sh #等价于sh -x script.sh
1.11.2 自定义调试功能
- Bash内建的调试功能仅能输出固定格式的调试信息,但在很多情况下,我们需要以自定义的格式显示调试信息,这可以通过 _DEBUG环境变量来建立这类调试风格。
#!/bin/bash
function DEBUG()
{
[ "$_DEBUG" == "on" ] && $@ || :
}
for i in { 1 2 3 }
do
DEBUG echo $i
done
- 我们在每一个需要打印调试信息的语句前面家DEBUG,如果没有把_DEBUG=on传递个脚本,那么调试信息就不会打印出来。在Bash中,:告诉shell不要进行任何操作。
1.11.3 利用shebang进行调试
- 把shebang从#!/bin/bash改成#!/bin/bash -xv,这样一来,不用任何其他选项就可以启用调试功能了。
1.11.4 调试功能常用参数
- -x选项将脚本中执行过的每一行都输出到stdout。除-x外,还有其他选项,列表如下:
选项 | 意义 |
---|
-x | 在执行时显示命令和参数 |
+x | 禁止调试 |
-v | 当命令进行读趋势显示输入 |
+x | 禁止打印输入 |
1.11.5 参考