第1章-小试牛刀(11调试脚本)

1.11.1实战演练
我们可以利用Bash内建的调试工具或者按照易于调试的方式编写脚本,方法如下所示。
(1)使用选项-x,启用shell脚本的跟踪调试功能:
bash -x script.sh

运行带有-x选项的脚本可以打印出所执行的每一行命令以及当前状态。
你也可以使用sh -x script。

(2)使用set -x和set +x对脚本进行部分调试。例如:


image.png

在上面的脚本中,只会打印出echo $i的调试信息,因为使用-x和+x对调试区域进行了限制。

该脚本并没有使用上例中的seq命令,而是用{start..end}来迭代从start到end之间的值。这个语言构件(construct)在执行速度上要比seq命令略快。

(3)前面介绍的调试方法是Bash内建的。它们以固定的格式生成调试信息。但是在很多情况下,我们需要使用自定义的调试信息。可以通过定义_DEBUG环境变量来启动或禁止调试及生成特定形式的信息。


image.png

可以将调试功能设置为on来运行上面的脚本:
chmod 755 script.sh
或chmod a+x script.sh
_DEBUG=on ./script.sh
我们在每一条需要打印调试信息的语句前加上DEBUG。如果没有把_DEBUG=on传递给脚本那么调试信息就不会打印出来。在Bash中,命令:告诉shell不要进行任何操作。

1.11.2工作原理
-x选项会输出脚本汇总执行过的每一行。不过,我们可能只关注其中某一部分代码。针对这种情况,可以在脚本中使用set builtin来启用或禁止调试打印。
set -x:在执行时显示参数和命令。
set +x:禁止调试。
set -v:当命令进行读取时显示输入。
set +v:禁止打印输入。

1.11.3补充内容
还有其他脚本调试的便捷方法,我们甚至可以巧妙地利用shebang来进行调试。

shebang的妙用
把shebang的秒用
把shebang从#!/bin/bash改成#!/bin/bash -xv,这样一来,不用任何其他选项就可以启动调试功能了。

如果每一行前面都加上+,那么久很难在默认输出中跟踪执行流程了。可以将环境变量PS4设置为$LINENO:,显示出每行的行号:
PS4=$LINE:

调试的输出信息可能会很长。如果使用了-x或set -x,调试输出会被发送到stderr。可以使用下面的命令将其重定向到文件中:
sh -x testScript.sh 2>debugout.txt

Bash 4.0以后及后续版本支持对调试输出使用自定义文件描述符:

exec 6> /tmp/debugout.txt
BASH_XTRACEFD=6

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 9,951评论 0 5
  • 本文全面系统地介绍了shell脚本调试技术,包括使用echo, tee, trap等命令输出关键信息,跟踪变量的值...
    liuzg0734阅读 4,417评论 0 14
  • 什么是运维 术语名词 IDC--(Internet Data Center)互联网数据中心,主要服务包括整机租用、...
    lyh165阅读 7,647评论 0 19
  • 又到一年开学季 父母送行脚步急 师生相见心欢喜 祈愿新年学业成
    远古之旅阅读 1,365评论 0 9
  • 那几年的夏日, 阳光特别明媚, 我们活在左岸, 那里风和日丽、鸟语花香, 左岸上有我们的象牙塔, 象牙塔里有我们,...
    音觅之阅读 1,813评论 0 1