我们可以利用bash内建的调试工具,或者按照易于调试的方式编写脚本;
1)使用选项-x,启用shell脚本的跟踪调试功能:
$ bash -x script.sh
运行带有-x标志的脚本可以打印出所执行的每一行命令以及当前状态。注意,也可以使用 sh -x script.
2)使用set -x和set +x对脚本进行部分调试。如
#!/bin/bash
for i in {1..6}
do
set -x
echo $i
set +x
done
echo "Script executed"
上面只会打印出echo $i的调试信息,因为使用了-x和+x对调试区域进行了限制。
3)前面介绍的调试手段是bash内建的。在很多情况下需要自定义格式显示调试信息。这可以通过传递_DEBUG环境变量来建立这类调试风格。
#/bin/bash
function DEBUG()
{
[ "$_DEBUG" == "on" ] && $@ || :
}
for i in {1..10}
do
DEBUG echo $i
done
可以将调试功能置为"on"来运行上面的脚本:
$ _DEBUG=on ./script.sh
我们在每一个需要打印调试信息的语句前加上DEBUG。如果没有把_DEBUG=on传递给脚本,那么调试信息就不会打印出来。在bash中,命令":"告诉shell不要进行任何操作。
注意:
$@:表示所有脚本参数的内容
$#:表示返回所有脚本参数的个数。
示例:编写如下shell脚本,保存为test.sh
#!/bin/sh
echo "number:$#"
echo "argume:$@"
执行脚本:
./test.sh first_arg second_arg
4)工作原理
-x标识将脚本中执行过的每一行都输出到stdout。不过,可能我们只关注脚本某些部分的命令及参数的打印输出。针对这种情况,可以在脚本中使用set builtin来启用或禁止调试打印。
set -x:在执行时显示参数和命令
set +x:禁止调试
set -v:当命令进行读取时显示输入。
set +v:禁止打印输入。
补充:还可以利用把#!/bin/bash改成#!/bin/bash -xv,这样一来,不用任何其他选项就可以启用调试功能了。
linux中shell变量$#,$@,$0,$1,$2的含义解释:
变量说明:
$$
Shell本身的PID(ProcessID)
$!
Shell最后运行的后台Process的PID
$?
最后运行的命令的结束代码(返回值)
$-
使用Set命令设定的Flag一览
$*
所有参数列表。如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出所有参数。
$@
所有参数列表。如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出所有参数。
$#
添加到Shell的参数个数
$0
Shell本身的文件名
$1~$n
添加到Shell的各参数值。$1是第1参数、$2是第2参数…。