问题描述
重击可让您捕获信号。是否有办法真正获取在特定信号(原因)之前立即打印的消息?我特别感兴趣的是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