站长资源脚本专栏

Linux Shell脚本系列教程(七):脚本调试

整理:jimmy2025/1/10浏览2
简介一、调试脚本调试功能是每一种编程语言都应该实现的重要特性之一,当出现一些始料未及的情况时,用它来生成脚本的运行信息,调试信息可以帮你弄清楚是什么原因使得程序发生崩溃或者行为异常。二、Bash内建调试功能使用Bash的内建调试功能,可以对整个脚本进行调试,也可以仅对脚本中的某些语句进行调试。#

一、调试脚本

调试功能是每一种编程语言都应该实现的重要特性之一,当出现一些始料未及的情况时,用它来生成脚本的运行信息,调试信息可以帮你弄清楚是什么原因使得程序发生崩溃或者行为异常。
二、Bash内建调试功能

使用Bash的内建调试功能,可以对整个脚本进行调试,也可以仅对脚本中的某些语句进行调试。
#使用set -x和set +x对脚本的某一句进行调试
复制代码 代码如下:
#!/bin/bash
for i in { 1 2 3 4 5 6 };
do
    set -x                         #开启调试功能
    echo $i                        #要调试的语句
    set +x                         #关闭调试功能
done
echo "Script executed."

复制代码 代码如下:
#使用 -x选项对整个脚本进行调试
bash -x script.sh                  #等价于sh -x script.sh

三、 自定义调试功能

Bash内建的调试功能仅能输出固定格式的调试信息,但在很多情况下,我们需要以自定义的格式显示调试信息,这可以通过 _DEBUG环境变量来建立这类调试风格。
复制代码 代码如下:
#使用_DEBUG=on bash script.sh运行下列脚本
#!/bin/bash
function DEBUG()
{
   [ "$_DEBUG" == "on" ] && $@ || : #使用_DEBUG环境变量调试
}
for i in { 1 2 3 }
do
    DEBUG echo $i
done     

我们在每一个需要打印调试信息的语句前面家DEBUG,如果没有把_DEBUG=on传递个脚本,那么调试信息就不会打印出来。在Bash中,:告诉shell不要进行任何操作。