如何解决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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。