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 +&