10分钟学会Bash调试

本文介绍了Bash脚本的调试方法,包括调试常用选项、跟踪脚本执行、日志打印和常见错误处理。通过设置选项如-x和-e,以及使用_PS4变量,可以有效地定位和解决脚本中的错误。此外,还讲解了如何通过日志开关控制调试信息的输出,以及处理不存在的变量、语法错误和其他错误情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

shell 是用户和操作系统交互的一个程序,经常用于执行一些自动化或者重复繁琐的任务,现在所有的 Linux 系统基本都自带了该程序,我们只需要编写好shell脚本,直接执行就可以了,不需要额外安装软件、配置编译环境,可以说使用起来非常的方便,但是它在调试方面常常令人头大,本文主要介绍shell脚本常用的调试方法

调试常用选项

调试shell脚本时,常常用到几个调试选项,让脚本在执行的过程中,会输出一些调试信息,根据调试信息,就可以定位出具体出问题的代码

具体的选项以及说明如下:

选项 说明
-x 输出结果之前,先输出执行的命令
-u 遇到不存在的变量就会报错,并停止执行
-e 发生错误时,终止执行
-n 检查语法错误
-o pipefail 管道子命令发生错误,终止执行

跟踪脚本的执行

  • 输出调试信息

通常,脚本执行之后,只有结果输出,当运行多条命令的时候,就会连续输出多条结果,无法分清哪条命令对应哪条结果, 使用 -x选项,会先输出将要执行的那一行命令的调试信息,然后再执行命令

现有脚本ta.sh,功能是输出当前日期, 内容如下

#!/bin/bash

echo "today is :"$(date +'%Y-%m-%d')

我们使用 -x选项来执行脚本,结果如下

[root@VM-0-2-centos shell_debug]# bash -x ta.sh 
++ date +%Y-%m-%d
+ echo 'today is :2021-07-10'
today is :2021-07-10

从结果中可以看到,在执行前打印出了每一行命令,行前面的 + 号表示调试信息,它实际是环境变量 PS4 的值, PS4 的第一个字符会根据嵌套层次进行重复,命令所处的层次越深,前面的 + 号越多

结果中第一行表示执行 date +'%Y-%m-%d'命令,它处于第内层,所以打印两个 + 号 ,第二行表示执行 echo "today is :"$(date +&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值