用内置变量调试shell脚本的方法
2014-03-12 00:00
681 查看
一般的shell脚本的调试基本都是echo 来处理遇到比较大的脚本的时候,就比较麻烦了,出了问题,还不是很好定位哪行代码出问题了。
其实shell内置的一些变量可以很好的解决这个问题:
$LINENO $FUNCNAME $BASH_LINENO 这几个变量记录了脚本当前的执行位置,以及正在执行的函数。具体可以可以man 文档页。
实例代码:a.sh
b.sh:
执行结果:
[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 函数 ,看到输出的差别了吧,我们可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用的,等等。。。。
其实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 函数 ,看到输出的差别了吧,我们可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用的,等等。。。。
相关文章推荐
- 用内置变量调试shell脚本的方法
- shell脚本里面一个很经典的调试方法(原创)
- Shell脚本中判断变量为数字的3种方法
- Shell脚本的调试方法
- Shell—启用Shell脚本调试模式的方法
- Shell向Perl脚本中传递变量的方法
- shell脚本调试方法
- 【Shell 编程基础第二部分】Shell里的流程控制、Shell里的函数及脚本调试方法!
- shell脚本里面一个很经典的调试方法(原创)
- Shell脚本(脚本结构和执行方法,date命令用法,脚本中的变量)
- shell脚本调试方法
- Bash脚本内置的调试方法技巧
- Shell向Perl脚本中传递变量的方法
- Shell脚本中判断变量为数字的3种方法
- Shell脚本中判断输入变量或者参数是否为空的方法
- shell脚本调试方法
- 通过脚本学shell编程——相关基础知识之shell内置变量命令(更新中)
- Shell脚本内置变量 和 awk脚本内置变量 比较
- shell 脚本调试方法
- Shell脚本调试方法