iis服务器助手广告广告
返回顶部
首页 > 资讯 > 操作系统 >详解bash中的脚本调试机制
  • 574
分享到

详解bash中的脚本调试机制

bash脚本调试 2022-06-04 23:06:44 574人浏览 薄情痞子
摘要

以调试模式运行脚本 通过bash -x <script>的方式可以在调试模式下运行整个脚本, bash会在在运行前打印出了每一行命令, 而且每行前面用+号表明命令的嵌套层数. > bash -x

以调试模式运行脚本

通过bash -x <script>的方式可以在调试模式下运行整个脚本, bash会在在运行前打印出了每一行命令, 而且每行前面用+号表明命令的嵌套层数.


> bash -x debug.sh 
+ echo 'First line'
First line # 输出结果没有加号
++ date # 先执行命令替换 两个加号是因为该命令嵌套在echo中
+ echo 'Print datetime: Thu 26 Mar 2020 08:21:28 PM CST Done.'
Print datetime: Thu 26 Mar 2020 08:21:28 PM CST Done.

如果脚本比较复杂, 我们可以通过使用环境变量PS4配合调试用的内置变量用于输出更加详细的信息:


> export PS4='+${BASH_SOURCE}:${LINENO}:${FUNCNAME[0]}: '
> bash -x debug.sh 
+debug.sh:3:: echo 'First line'
First line
++debug.sh:4:: date
+debug.sh:4:: echo 'Print datetime: Thu 26 Mar 2020 08:35:59 PM CST Done.'
Print datetime: Thu 26 Mar 2020 08:35:59 PM CST Done.

我们也可以使用trap的DEBUG关键字在解释执行每一行脚本之前执行指定的命令或函数:


trap 'echo "VARIABLE-TRACE> \$variable = \"$variable\""' DEBUG
variable=29
let variable++
let variable*=5
exit 0

# 输出如下
VARIABLE-TRACE> $variable = ""
VARIABLE-TRACE> $variable = "29"
VARIABLE-TRACE> $variable = "30"
VARIABLE-TRACE> $variable = "150"

还可以使用trap的ERR关键字用于在解释出现错误时执行预设的操作, 例如打印出错的命令:


trap 'echo $BASH_COMMAND' ERR

但鉴于使用trap进行调试的执行效率过低, 建议在较为复杂的脚本中直接使用调试选项或者使用bashdb等调试工具.

高级调试

查看函数调用信息

在函数中使用内置命令caller能够把函数的调用信息输出到stdout, 但要注意该命令必须在函数内部调用.


#!/usr/bin/bash

func1 () {
  for i in `seq 0 3`
  do
    echo -e "Level$i\t  `caller $i`"
  done
}

func2 () {
  func1
}

func3 () {
  func2
}

func3
caller 0 # 必须在函数中调用 否则无输出
exit 0

运行该脚本可以得到以下输出:

Level0      11 func2 call.sh  # func1 的直接调用者
Level1      15 func3 call.sh  # 一层间接调用
Level2      18 main call.sh   # 二层间接调用
Level3      # 无输出 因为没有第三层调用

局部调试

可以通过set命令构造局部调试块,我们可以按照如下方式添加局部调试:


set -x
date
set +x

> bash script1.sh # 不需要添加调试参数
The script starts now.

+ date
Fri 28 Feb 2020 06:23:04 PM CST
+ set +x

This is a string: black
And this is a number: 9

调试参数表

短命令 长命令 效果
set -f set -o noglob 对文件名停用元字符匹配
set -v set -o verbose 打印输入的命令
set -x set -o xtrace 命令行首打印+,执行出错会打印详细信息

调试用的参数可以在运行中动态叠加或删除:


> set -v
> date
date 
Fri 28 Feb 2020 06:54:47 PM CST
> set -x      # 参数可以累加
date        # -v 的效果
+ date       # -x 的效果
Fri 28 Feb 2020 06:55:37 PM CST
> set +vx      # 取消参数
set +vx

通过使用-f选项可以显著减少脚本中的转义字符:


> ls ?
x86_64-pc-linux-gnu-library
> set -f      # 停用元字符匹配
> ls ?
ls: cannot access '?': No such file or directory
> touch ?
> ls ?
'?'
> rm ?
> set +f -x   # 选项 x 还可以用于显示详细错误信息
> aaa
+ aaa
+ '[' -x /usr/lib/command-not-found ']'
+ /usr/lib/command-not-found -- aaa

Command 'aaa' not found, did you mean:

 command 'aha' from deb aha (0.5-1)
 command 'jaaa' from deb jaaa (0.8.4-4)
 command 'aa' from deb astronomical-almanac (5.6-6)

Try: sudo apt install <deb name>

+ return 127

默认调试

也可以直接在脚本第一行添加参数让脚本默认以调试模式启动:


#!/bin/bash -xv

还可以在可能出错的命令前用echo输出调试信息:


echo "debug message: now attempting to start w command"; w # 用 ; 对要执行的命令排序
echo "Variable VARNAME is now set to $VARNAME."

设置选项辅助调试

为了方便调试,我们可以使用set命令对bash的选项进行设置:


> set -o # 查看所有选项的开关状态
> set -o | grep xtrace
xtrace     off
> set -x # 等价于 set -o xtrace
> set -o | grep xtrace 
+ grep --color=auto xtrace
+ set -o
xtrace     on
> set +x # 等价于 set +o xtrace
+ set +x
> set -o | grep xtrace
xtrace     off

常用调试选项

引用为定义变量时报错:


> unset $VAR;echo $VAR

> set -u # 等价于 set -o nounset
> echo $var
bash: var: unbound variable

为防止误操作覆盖文件中的数据, 设置禁止重定向到已经存在的文件:


> set -C # 等价于 set -o noclobber
> touch test
> date > test
bash: test: cannot overwrite existing file

设置不解析通配符:


> set -f # 等价于 set -o noglob
> touch *
> ll *
-rw-rw-r-- 1 remilia remilia 0 Mar 1 20:09 '*'

到此这篇关于详解bash中的脚本调试机制的文章就介绍到这了,更多相关bash 脚本调试 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

--结束END--

本文标题: 详解bash中的脚本调试机制

本文链接: https://www.lsjlt.com/news/21014.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 有哪些Bash脚本内置的调试方法
    本篇内容介绍了“有哪些Bash脚本内置的调试方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!用 Bash 写的脚本也可以进行调试,和 Py...
    99+
    2023-06-09
  • python中如何调试脚本
    小编给大家分享一下python中如何调试脚本,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!调试脚本我们可以在 模块的帮助下在 Python 脚本中设置断点。请按照...
    99+
    2023-06-27
  • Bash脚本中如何调用Java函数?
    Bash脚本是一种常用的命令行脚本语言,而Java是一种面向对象的编程语言。在实际的开发过程中,我们可能会遇到需要在Bash脚本中调用Java函数的情况。本文将介绍如何在Bash脚本中调用Java函数。 环境准备 在开始之前,我们需要...
    99+
    2023-08-19
    函数 bash spring
  • 如何在Java中调用Bash脚本中的函数?
    Java和Bash都是广泛使用的编程语言,它们各有优势,Java在面向对象编程和跨平台方面非常强大,而Bash则在脚本编程和系统管理方面非常实用。在一些项目中,我们可能需要在Java代码中调用Bash脚本中的函数,这是一个比较常见的需求。本...
    99+
    2023-08-19
    函数 bash spring
  • 想要在 Linux 上使用 ASP 调用 API?试试这些 Bash 脚本!
    ASP (Active Server Pages) 是一种由微软开发的动态网页技术,通常用于在 Windows 系统上开发网页应用。但是,如果你需要在 Linux 系统上使用 ASP 调用 API,该怎么办呢?本文将介绍一些 Bash 脚...
    99+
    2023-06-24
    bash api linux
  • IE10 Error.stack脚本调试的方法
    本文小编为大家详细介绍“IE10 Error.stack脚本调试的方法”,内容详细,步骤清晰,细节处理妥当,希望这篇“IE10 Error.stack脚本调试的方法”文章能帮助大家解决疑惑,下面跟着小编的思...
    99+
    2024-04-02
  • Golang 动态脚本调研详解
    目录一、技术背景1.1 程序的动态链接技术1.1.1 动态链接库1.1.2 动态共享对象1.1.3 非编译语言的动态技术1.2 Golang 的动态技术二、Golang 的第三方解释...
    99+
    2024-04-02
  • Pig中调试脚本的方法是什么
    在Pig中调试脚本的方法有以下几种: 使用DESCRIBE命令查看数据表的结构和模式,确保输入数据和预期的一致。 使用DUMP命令...
    99+
    2024-04-02
  • python调用bash shell脚本的方法是什么
    本篇文章为大家展示了python调用bash shell脚本的方法是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. os.system()help(os.system)1.1. d...
    99+
    2023-06-22
  • 一文详解Python中的重试机制
    目录介绍1. 最基本的重试2. 设置停止基本条件3. 设置何时进行重试4. 重试后错误重新抛出5. 设置回调函数介绍 为了避免由于一些网络或等其他不可控因素,而引起的功能性问题。比如...
    99+
    2024-04-02
  • 详解Jmeter中的BeanShell脚本
    在利用jmeter进行接口测试或者性能测试的时候,我们需要处理一些复杂的请求,此时就需要利用beanshell脚本了,BeanShell是一种完全符合Java语法规范的脚本语言,并且...
    99+
    2024-04-02
  • Bash脚本中Sleep命令的使用
    目录等待时间的格式使用变量控制等待时间结论在编写Bash脚本时,有时需要在程序执行过程中加入一些等待时间,例如等待某个操作完成或等待某个进程退出。此时可以使用sleep命令来实现。 sleep命令可以让脚本暂停执行一段时...
    99+
    2023-05-05
    Bash Sleep命令 Bash Sleep
  • Python retrying 重试机制详解
    目录循环加判断retrying总结 我们在程序开发中,经常会需要请求一些外部的接口资源,而且我们不能保证每次请求一定会成功,所以这些涉及到网络请求的代码片段就需要加上重试机制。下面来...
    99+
    2024-04-02
  • 怎么在Linux中启用Shell脚本的调试模式
    本篇内容主要讲解“怎么在Linux中启用Shell脚本的调试模式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在Linux中启用Shell脚本的调试模式”吧!脚本是存储在一个文件的一系列命令...
    99+
    2023-06-16
  • 如何在Linux中启用Shell脚本的调试模式
    这篇文章的内容主要围绕如何在Linux中启用Shell脚本的调试模式进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!在Linux系统中脚本是一个可以储...
    99+
    2023-06-28
  • 详解Python脚本如何设置试用期
    目录1、获取网络时间2、上锁3、编译 pyd程序员可能会私下给别人开发一些工具,但是通常要给别人试用一下,但是万一别人试用后,把你拉黑,那就白忙活了。今天就分享如何在 Python ...
    99+
    2024-04-02
  • Bash脚本中如何使用Java API实现自动化测试?
    自动化测试是软件开发中不可或缺的一环,它可以提高测试效率,降低测试成本,同时也可以保证软件质量。在自动化测试中,Bash脚本和Java API是两个非常重要的工具。本文将介绍如何在Bash脚本中使用Java API实现自动化测试。 一、B...
    99+
    2023-10-27
    api django bash
  • 如何解决Shell脚本bash: ./t.sh:/bin/bash^M:损坏的解释器
    这篇文章主要讲解了“如何解决Shell脚本bash: ./t.sh:/bin/bash^M:损坏的解释器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何解决Shell脚本bash: ./t...
    99+
    2023-06-09
  • java回调机制实例详解
    java回调机制实例详解以前不理解什么叫回调,天天听人家说加一个回调方法啥的,心里想我草,什么叫回调方法啊?然后自己就在网上找啊找啊找,找了很多也不是很明白,现在知道了,所谓回调:就是A类中调用B类中的某个方法C,然后B类中反过来调用A类中...
    99+
    2023-05-31
    java 回调机制 ava
  • 怎么在Shell脚本中跟踪调试命令的执行
    这篇文章主要介绍怎么在Shell脚本中跟踪调试命令的执行,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!本系列的前面部分清晰地阐明了另外两种 shell 脚本调试模式:详细模式和语法检查模式,并用易于理解的例子展示了如...
    99+
    2023-06-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作