我有一个shell脚本与以下一行在它:
[ "$DEBUG" == 'true' ] && set -x
set -x启用了一种shell模式,其中所有执行的命令都打印到终端。在你的例子中,它显然是用于调试的,这是set -x的一个典型用例:在执行每个命令时打印它可以帮助你可视化脚本的控制流,如果它没有像预期的那样运行。
set -x
set +x禁用它。
set +x
打印简单命令的跟踪,对于命令,大小写命令,选择 命令,以及命令及其参数的算术或 展开之后和展开之前的关联单词列表 执行。PS4变量的值被展开,结果是 . Value在命令及其展开参数之前打印
打印简单命令的跟踪,对于命令,大小写命令,选择 命令,以及命令及其参数的算术或 展开之后和展开之前的关联单词列表 执行。PS4变量的值被展开,结果是
(源)
set -x echo `expr 10 + 20 ` + expr 10 + 20 + echo 30 30
set +x echo `expr 10 + 20 ` 30
上面的例子说明了set -x的用法。使用时,上述算术表达式已展开。我们可以看到单行是如何一步一步求值的。
expr
echo
要了解更多关于set的信息,请访问这个链接
当涉及到shell脚本时,
当执行模式选择为DEBUG时,脚本可能已经打印了一些额外的信息行。传统上,当调用带有可选参数(如-d)的脚本时,人们习惯于启用调试模式
DEBUG
-d
-u:默认关闭。当激活时,当使用未配置的变量时将显示错误消息。 -v:默认为inactive。激活后,将显示信息的原始内容(无可变分辨率) .输出 -x:默认为inactive。如果激活,命令内容将在命令运行之前显示(变量解析后,有 是++符号)。
-u:默认关闭。当激活时,当使用未配置的变量时将显示错误消息。
-v:默认为inactive。激活后,将显示信息的原始内容(无可变分辨率)
-x:默认为inactive。如果激活,命令内容将在命令运行之前显示(变量解析后,有 是++符号)。
比较以下差异:
/ # set -v && echo $HOME /root / # set +v && echo $HOME set +v && echo $HOME /root / # set -x && echo $HOME + echo /root /root / # set +x && echo $HOME + set +x /root / # set -u && echo $NOSET /bin/sh: NOSET: parameter not set / # set +u && echo $NOSET