脚本编程

Shell脚本的简单排错法及调试程序bashdb

Jager · 2月19日 · 2014年 · · 8927次已读

Jboss 的研究稍有卡壳,那就来点基础教程好了。

与众多脚本语言一样,Shell 脚本在执行时出错是很常见的,最简单的原因无外乎脚本在编写的过程中出现了语法错误或者不小心输错了命令等。找出脚本中的错误是很重要的能力。比如,我经常不小心会把 echo 命令写成了 ehco,那么执行就会出现下面这种情况:

[root@localhost ~]# sh test
test: line 2: ehco: command not found

从报错信息很容易判断出错的原因是“命令不存在”。重新编辑这个文件修改成 echo 就可以解决。如果只是语法或命令上的错误还是比较容易辨别的,但往往一些逻辑或算法错误就不容易发现,因为语法正确且本身不会造成程序运行错误。比如说下面的脚本,本来想连续 10 次做某些操作的,结果却迟迟没输出。仔细观察一下就知道是陷入了死循环。

[root@localhost ~]# cat test
#!/bin/bash
for ((i=10;i>0;i=i+1))
    do
         #run command there
    done

如果在上面的循环中加入 echo 语句,就容易发现问题了。而如果是单次循环过快,根本来不及看就进入了下一次循环,那这时就可以加入 sleep 命令降低单次循环的速度,比如使用 sleep 2,单次循环就将延时 2s,给我们带来足够的观察时间:

[root@localhost ~]# cat test
#!/bin/bash
for ((i=10;i>0;i=i+1))
    do
         #run command there
         echo "i=$i";
    done

为了更清晰的看到脚本运行的过程,我们还可以借助-x 参数来观察脚本的运行情况。比如上面的脚本,我们使用-x 参数执行就可以发现,变量 i 的值一直在增加,且一直满足 x>0 的条件,所以这是一个死循环。所以,我们只要将 i=i+1 修改成 i=i-1 即可。

[root@localhost ~]# sh -x test
+ (( i=10 ))
+ (( i>0 ))
+ echo i=10
i=10
+ sleep 2
+ (( i=i+1 ))
+ (( i>0 ))
+ echo i=11
i=11
+ sleep 2
+ (( i=i+1 ))
+ (( i>0 ))
+ echo i=12
i=12
+ sleep 2
[Ctrl +c]终止脚本

Shell 本身并没有提供更好的排错工具,为了更加精细地调试 Shell 脚本,我们可以借助第三方工具 bashdb。这是一个类似于 GDB 的脚本调试软件,小巧而强大,具有这只断点、单步执行、观察变量等功能。下载时请根据所使用的 bash 版本选择相应的 bashdb,否则会提示因为版本不符合而无法安装。

如下查看 bash 版本:

[root@localhost ~]# bash --version
GNU bash, version 3.1.25(1)-release (x86_64-redhat-linux-gnu)
Copyright (C) 2005 Free Software Foundation, Inc.

如下安装:

#第一步:在终端使用 wget 下载 3.1 版本
wget  http://ftp.jaist.ac.jp/pub/sourceforge/b/ba/bashdb/bashdb/3.1-0.09/bashdb-3.1-0.09.tar.gz
#第二步:解压并进入目录
tar -zxvf  bashdb-3.1-0.09.tar.gz
cd  bashdb-3.1-0.09
#第三步:配置及编译安装
./configure
make && make install

安装完成后,我们便可以在终端使用 bashdb 命令了,改命令典型用法如下:

[root@localhost ~]# bashdb --debug 脚本名

常用参数:

一、列出代码和查询代码类:
l  列出当前行以下的 10 行
-  列出正在执行的代码行的前面 10 行
.  回到正在执行的代码行
w  列出正在执行的代码行前后的代码
/pat/ 向后搜索 pat
?pat?向前搜索 pat
二、Debug 控制类:
h     帮助
help  命令 得到命令的具体信息
q     退出 bashdb
x     算数表达式 计算算数表达式的值,并显示出来
!!    空格 Shell 命令 参数 执行 shell 命令
使用 bashdb 进行 debug 的常用命令(cont.)
三、控制脚本执行类:
n   执行下一条语句,遇到函数,不进入函数里面执行,将函数当作黑盒
s n 单步执行 n 次,遇到函数进入函数里面
b   行号 n 在行号 n 处设置断点
del 行号 n 撤销行号 n 处的断点
c   行号 n 一直执行到行号 n 处
R   重新启动当前调试脚本
Finish 执行到程序最后
cond n expr 条件断点
32 条回应
  1. PHP二次开发 2014-2-19 · 20:42

    还真没搞过shell

    • avatar
      Jager 2014-2-19 · 20:50

      呵呵,也是脚本的一类了,你PHP那么厉害,这个随便学学就会了。

  2. 刘俊博客 2014-2-20 · 10:10

    [汗] 不懂

    • avatar
      Jager 2014-2-20 · 11:31

      呵呵,找些感兴趣的看看~

    • avatar
      Jager 2014-2-20 · 11:33

      在公司打开你的网站,留言框无法出来,汗~~不知道是不是哪里被封了。。回家再回访你,要不咱们友个链如何?

  3. 圆月博客 2014-2-20 · 10:56

    技术活,我表示不懂 [泪]

    • avatar
      Jager 2014-2-20 · 11:31

      呵呵,其实我想说技术活的文章最不受欢迎~~

  4. 漫道狂徒 2014-2-20 · 11:01

    看着你的博客,我才发现,我写的都是啥东西

    • avatar
      Jager 2014-2-20 · 11:30

      怎么了?

  5. 寇铈鑫 2014-2-20 · 11:42

    看来你是技术男啊 真心看不懂

    • avatar
      Jager 2014-2-20 · 11:45

      呵呵,应该说是屌丝一枚。

      • 寇铈鑫 2014-2-20 · 11:49

        技术男都是人才啊

        • avatar
          Jager 2014-2-20 · 11:51

          技术男一般都只是穷打工的。。

          • 寇铈鑫 2014-2-20 · 12:08

            http://www.ldsun.com/896.html 博主 看下这个吧 你就懂了 不是广告哦 只是感觉好 所以推荐下

            • avatar
              Jager 2014-2-20 · 12:21

              嗯,可惜我不是做开发的~不过系统管理员也能排前20名,也不错哈~呵呵

              • 寇铈鑫 2014-2-20 · 13:15

                所以么 你很有潜质的

                • avatar
                  Jager 2014-2-20 · 13:36

                  [哈哈]

  6. 垂直绿化 2014-2-20 · 17:17

    看起来好友技术,收藏先。

    • avatar
      Jager 2014-2-20 · 17:30

      见笑了~

  7. 73花生博客 2014-2-22 · 13:01

    博主是什么专业

    • avatar
      Jager 2014-2-22 · 13:32

      大学通信工程,现已荒废。。
      懂得太泛,而正好做运维要懂得广。。所以现在职业是linux服务器运维,或者叫linux系统管理员。

      • 73花生博客 2014-2-22 · 13:36

        我这服务器好像就是LINUX的,不过服务商总说是Win的,哪个好

        • avatar
          Jager 2014-2-22 · 13:55

          至少我知道wordpress在linux中跑得更顺畅,兼容性更好。最常见的例子,WP后台登陆,在linux主机要比WIN主机要快~~
          linux中PHP支持拓展的功能模块要多些。

          • 73花生博客 2014-2-22 · 13:56

            你卖空间嘛,我要换空间的话找你呗

            • avatar
              Jager 2014-2-22 · 14:07

              我倒是不卖空间,只是点击我博客底部的【野草】链接去买,我到是可以拿十来块的提成。我现在用的就是这个野草主机,打折的时候买的:100元/年 1G空间/30G流量/无限绑定域名和数据,不算便宜也不算太贵。可以看下这篇文章:https://zhang.ge/1276.html

              记得看他有没有出打折优惠码~~打折才去买。

              • 73花生博客 2014-2-22 · 14:18

                有没有帮倒空间的服务,我不会整

                • avatar
                  Jager 2014-2-22 · 14:22

                  倒空间?你是说帮忙拷贝代码去新站点还是?如果是转移站点和解析之类的,这野草客服都会帮你弄好。

                  • 73花生博客 2014-2-22 · 14:33

                    是啊,就是把我这个空间的东西,转到那个空间。昂那就好,要是换的话,就来找你了

                    • avatar
                      Jager 2014-2-22 · 14:43

                      [ok]