用内置变量调试shell脚本的方法
更新时间:2014年03月12日 10:54:27 作者:
这篇文章主要介绍了用内置变量调试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]}"
}
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
}
../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 函数 ,看到输出的差别了吧,我们可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用的,等等。。。。
您可能感兴趣的文章:
相关文章
利用linux的timerfd_create实现计时器示例分享
这篇文章主要介绍了利用linux的timerfd_create实现计时器示例,需要的朋友可以参考下2014-02-02
Linux中使用locate和find进行不区分大小写的文件搜索
在日常使用计算机的过程中,尤其是处理大量文件时,快速找到特定文件变得尤为重要,Linux系统提供了许多命令行工具,其中“locate”和“find”是两个常用的文件搜索工具,本文给大家介绍了如何在Linux中使用locate和find进行不区分大小写的文件搜索2024-05-05


最新评论