Bash:从刚刚捕获的错误中获取消息

问题描述

重击可让您捕获信号。是否有办法真正获取在特定信号(原因)之前立即打印的消息?我特别感兴趣的是ERR。我知道并非所有信号都与一条消息相关联。只是想知道bash本身在引发错误时是否设置了变量或其他内容

示例代码

#!/bin/bash
# Running bash 5.0

handler () {
    echo "Handling the error"
    exit 0
}

trap handler ERR

notacommand

上面的代码将打印:

./example.sh: line 11: notacommand: command not found

有没有办法在处理程序中查看此消息?

编辑:我知道我可以将所有输出保存到文件中,然后在发生错误时读取该文件的尾部。这对我来说似乎很麻烦,因为写入该文件的最后一条消息可能不是错误(尤其是如果脚本中的任何子进程都以&开始)。我希望bash可以设置var或其他内容,就像设置$1$?$RANDOM等一样。

解决方法

将bash的stderr重定向到文件:

#!/bin/bash
# Running bash 5.0

log="error.txt"
exec 2>"$log"

handler () {
 echo "Handling this error: $(< "$log")"
 exit 0
}

trap "handler" ERR
trap "rm $log" EXIT

notacommand

输出:

Handling this error: ./example.sh: line 15: notacommand: command not found

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...