在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
用 Bash 写的脚本也可以进行调试,和 Python,Perl 等解释型语言一样。新建一个名为 servinfo 的脚本并增加可执行权限: 复制代码 代码如下: $ vi servinfo #!/bin/bash echo "Hostname: $(hostname)" $ chmod +x servinfo 用 bash -x 来调试上述脚本,Bash 先打印出每行脚本,再打印出每行脚本的执行结果: 复制代码 代码如下: $ bash -x servinfo ++ hostname + echo 'Hostname: vpsee' Hostname: vpsee ++ date + echo 'Date: Thu Sep 3 19:33:48 SAST 2009' Date: Thu Sep 3 19:33:48 SAST 2009 ++ uname -mrs + echo 'Kernel: Linux 2.6.18-128.4.1.el5 i686' Kernel: Linux 2.6.18-128.4.1.el5 i686 如果想同时打印行号的话,可以在脚本开头加上: 复制代码 代码如下: 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 把要调试的部分包含进来: 复制代码 代码如下: #!/bin/bash echo "Hostname: $(hostname)" 这个时候可以直接运行脚本,不需要执行 bash -x 了: 复制代码 代码如下: $ ./servinfo Hostname: vpsee ++ date + echo 'Date: Thu Sep 3 19:46:53 SAST 2009' Date: Thu Sep 3 19:46:53 SAST 2009 + set +x Kernel: Linux 2.6.18-128.4.1.el5 i686 如果要调试一个非常复杂的 Bash 脚本的话,建议用专门的调试工具,比如:bashdb |
请发表评论