我有一些关键的bash脚本,这些脚本由我无法控制的代码调用,而且我看不到他们的控制台输出。我想要完整地了解这些脚本的作用,以便以后分析。为此,我想让每个脚本都自我跟踪。以下是我目前正在做的事情:
#!/bin/bash
# if last arg is not '_worker_', relaunch with stdout and stderr
# redirected to my log file...
if [[ "$BASH_ARGV" != "_worker_" ]]; then
$0 "$@" _worker_ >>/some_log_file 2>&1 # add tee if console output wanted
exit $?
fi
# rest of script follows...
有更好,更清洁的方法吗?
答案 0 :(得分:13)
#!/bin/bash
exec >>log_file 2>&1
echo Hello world
date
exec
有关于重定向的神奇行为:“如果未指定命令,则任何重定向在当前shell中生效,并且返回状态为0.如果存在重定向错误,返回状态为1.“
另外,关于原始解决方案,exec "$0"
优于"$0"; exit $?
,因为前者在子进程退出之前不会留下额外的shell进程。
答案 1 :(得分:2)
也许您正在寻找set -x
?
答案 2 :(得分:0)
您可以检查支持bash的常见开源跟踪库。
当前可用的组件是由bash编写的脚本,很快就可以使用Python和C ++。另外还有:Ruby,Java,JavaScript,SQL,PowerShell,......
许可证是Apache-2.0
WKR Arno-Can Uestuensoez