shell脚本调试

Posted 沉心十年

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell脚本调试相关的知识,希望对你有一定的参考价值。

1、使用dos2unix命令处理在windows下开发的脚本

将windows下编辑的脚本放置到linux下执行的情况如下:

[[email protected] ~]# cat -v nginx.sh 
#!/bin/bash^M
a=1 n^M
sum=0    ^M
while ((a <=50 ))^M
do^M
    ((sum=sum+a)) ^M
    ((a++)) ^M
done^M

[[email protected] ~]# sh nginx.sh     #执行脚本 
: command not found
: command not found
‘ginx.sh: line 4: syntax error near unexpected token `
‘ginx.sh: line 4: `while ((i <=100 ))

在上述的过程中,在windows下开发的脚本,检查没有问题。但在linux系统中执行时出现莫名其妙的语法错误。这时,最好执行dos2unix格式化一下。

#格式化命令安装
[[email protected] ~]# yum -y install dos2unix
#使用方法
[[email protected] ~]# dos2unix nginx.sh 
dos2unix: converting file nginx.sh to UNIX format ...
#再次查看

[[email protected] ~]# cat -v nginx.sh
#!/bin/bash
a=1 n
sum=0
while ((a <=50 ))
do
((sum=sum+a))
((a++))
done

提示:^M消失了,说明已正常。windows下代码的换行符合linux下的不一样,导致了本例的问题。在windows下开发的脚本或非自己所写,需要使用dos2unix格式化,防止执行过程中出现错误。

2、使用bash命令参数调试

[[email protected] ~]# sh [-nvx] nginx.sh

参数说明:
-n:不会执行该脚本,仅查询脚本语法是否有问题,并给出错误提示
-v:在执行脚本时,先将脚本的内容输出到屏幕上,然后执行脚本。如果有错误,也会给出错误提示。
-x:将执行的脚本内容及输出显示到屏幕上,这是对调试很有用的参数。

注:参数-x是追踪脚本执行过程一种非常好的方法,他可以在执行前列出所执行的所有程序段。

       如果程序段落,在输出时,最前面会加上+符号,表示程序代码。

       如果执行脚本发生问题(非语法问题时),利用-x参数,就可以知道问题出在哪一行

       一般情况下如果是调试逻辑错误的脚本,用-x的参数效果更佳。

      缺点:加载系统函数库等很多我们不想查看其整个过程的脚本时,会有太多输出,导致很难查看所需要的内容。

3、使用echo命令调试

echo命令是最有用的调试脚本的工具之一。一般应在可能出现的问题的脚本重要的部分加入echo命令(在变量读取或修改操作的前后加入echo命令,并紧挨着退出命令exit)。此调试方法不仅适用于shell,在php、Python语言中经常使用。

范例:

[[email protected] ~]# cat  debug.sh
#!/bin/bash
read -p "please input two number:" a b
echo $a $b     #输出变量,查看获取的变量值
exit           #退出脚本,不继续执行脚本。

if (($a < $b))
  then
    echo "$a<$b"
elif (($a == $b))
  then
    echo "$a=$b"
else
    echo "$a>$b"
fi

4、使用set命令调试部分脚本内容

set 命令也可以用于辅助脚本调试。

set命令常用的调试选项:

  • set -n :读取命令单并不执行
  • set -v :显示读取的所有行
  • set -x :显示所有命令及其参数

提示:通过set -x 命令开启调试功能,而通过set +x 关闭调试功能。

set命令最大优点是,和bash -x相比,set -x可以缩小调试的作用域。

[[email protected] ~]# cat debug.sh

#!/bin/bash
read -p "please input two number:" a b
set -x    #开启调试
if (($a < $b))
  then
    echo "$a<$b"
elif (($a == $b))
  then
    echo "$a=$b"
else
    echo "$a>$b"
fi
set +x    #结束调试,只针对set -x 和set +x 之间的脚本进行调试

echo "完美"

执行脚本查看调试结果:

[[email protected] ~]# sh debug.sh 
please input two number:2 2
+ (( 2 < 2 ))
+ (( 2 == 2 ))
+ echo 2=2
2=2
+ set +x
完美

提示:加了set +x,在运行脚本的时候,无需使用sh -x 。
















以上是关于shell脚本调试的主要内容,如果未能解决你的问题,请参考以下文章

Shell编程-14-Shell脚本规范及调试

Shell之脚本检查与调试

shell 脚本 片段

用于确保在任何给定时间仅运行一个 shell 脚本的 shell 片段 [重复]

PowerShell ISE:调试从 power-shell 脚本调用的另一个 power-shell 脚本

常用python日期日志获取内容循环的代码片段