1.11调试脚本

我们可以利用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参数…。 

原文地址:https://www.cnblogs.com/gary-guo/p/6096503.html