Chinaunix首页 | 论坛 | 博客
  • 博客访问: 80677
  • 博文数量: 16
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 142
  • 用 户 组: 普通用户
  • 注册时间: 2013-02-26 19:43
个人简介

与你相遇,共守终老。

文章分类

全部博文(16)

文章存档

2013年(16)

我的朋友

分类: LINUX

2013-02-26 19:53:49

用 Bash 写的也可以进行调试,和 , 等解释型语言一样。

新建一个名为 servinfo 的脚本并增加可执行权限: 用 bash -x 来调试上述脚本,Bash 先打印出每行脚本,再打印出每行脚本的执行结果:

点击(此处)折叠或打开

  1. $ vi servinfo
  2. #!/bin/bash
  3. echo "Hostname: $(hostname)"
  4. echo "Date: $(date)"
  5. echo "Kernel: $(uname -mrs)"
  6. $ chmod +x servinfo
如果想同时打印行号的话,可以在脚本开头加上:

点击(此处)折叠或打开

  1. export PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
执行结果为:
$ bash -x servinfo
+ export 'PS4=+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
+ PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
++4:5:: hostname
+4:5:: echo 'Hostname: vpsee'
Hostname: vpsee
++4:6:: date
+4:6:: echo 'Date: Thu Sep  3 19:42:06 SAST 2009'
Date: Thu Sep  3 19:42:06 SAST 2009
++4:7:: uname -mrs
+4:7:: echo 'Kernel: Linux 2.6.18-128.4.1.el5 i686'
Kernel: Linux 2.6.18-128.4.1.el5 i686

如果只想调试其中几行脚本的话可以用 set -x 和 set +x 把要调试的部分包含进来:

点击(此处)折叠或打开

  1. #!/bin/bash

  2. echo "Hostname: $(hostname)"
  3. set -x
  4. echo "Date: $(date)"
  5. set +x
  6. echo "Kernel: $(uname -mrs)"
这个时候可以直接运行脚本,不需要执行 bash -x 了:

点击(此处)折叠或打开

  1. $ ./servinfo
  2. Hostname: vpsee
  3. ++ date
  4. + echo 'Date: Thu Sep 3 19:46:53 SAST 2009'
  5. Date: Thu Sep 3 19:46:53 SAST 2009
  6. + set +x
  7. Kernel: Linux 2.6.18-128.4.1.el5 i686
日志输出

跟踪日志有时候太多了,多得都受不了,而且,输出的内容很难阅读。一般来说,我们很多时候只关心于条件表达式,变量值,或是函数调用,或是循环等。。在这种情况下,log一些感兴趣的特定的信息,可能会更好。

使用log前,我们先写一个函数:

点击(此处)折叠或打开

  1. _log() {
  2.     if [ "$_DEBUG" == "true" ]; then
  3.         echo 1>&2 "$@"
  4.     fi
  5. }
于是,你就可以在你的脚本中如下使用:

点击(此处)折叠或打开

  1. _log "Copying files..."
  2. cp src/* dst/ 
我们可以看到,上面那个_log函数,需要检查一个_DEBUG 变量,只有这个变量是真,才会真正开发输出日志。这样,你就只需要控制这个开关,而不需要删除你的debug信息。

点击(此处)折叠或打开

  1. $ _DEBUG=true ./example_script.sh
如果要调试一个非常复杂的 Bash 脚本的话,建议用专门的调试工具,比如:
阅读(1405) | 评论(1) | 转发(0) |
0

上一篇:没有了

下一篇:理解linux中的重定向及管道

给主人留下些什么吧!~~

myspring9992013-02-26 20:10:37

第一次知道,shell也有专用的调试方法,惊。