当前位置: 移动技术网 > 网络运营>服务器>Linux > 用内置变量调试shell脚本的方法

用内置变量调试shell脚本的方法

2017年12月12日  | 移动技术网网络运营  | 我要评论
一般的shell脚本的调试基本都是echo 来处理遇到比较大的脚本的时候,就比较麻烦了,出了问题,还不是很好定位哪行代码出问题了。其实shell内置的一些变量可以很好的解决

一般的shell脚本的调试基本都是echo 来处理遇到比较大的脚本的时候,就比较麻烦了,出了问题,还不是很好定位哪行代码出问题了。
其实shell内置的一些变量可以很好的解决这个问题:
$lineno  $funcname $bash_lineno 这几个变量记录了脚本当前的执行位置,以及正在执行的函数。具体可以可以man 文档页。

实例代码:a.sh

复制代码 代码如下:
#!/bin/bash
abc() {
echo "wo shi abc()"
echo  "func: $funcname  ln: $lineno ln2:${bash_lineno[1]} brother: ${funcname[1]}"
}

b.sh:
复制代码 代码如下:
#!/bin/bash
../a.sh
abc
cdf() {
abc
}


执行结果:
[root@node2 ~]# ./b.sh
[code]wo shi abc()
func: abc  ln: 5 ln2:0 brother: main
wo shi abc()func: abc  ln: 5 ln2:9 brother: cdf
我在b.sh 里写了cdf 函数调用 abc 函数 ,看到输出的差别了吧,我们可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用的,等等。。。。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网