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

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/

一般的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 函数 ,看到输出的差别了吧,我们可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用的,等等。。。。

免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞10 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容