我假设你仍然看到STDERR和STDOUT在终端上。你可以去Josh Kelley的答案,但我发现在背景中保持尾巴,输出你的日志文件非常hackish和cludgy。注意你需要保持一个exra FD,然后清除它,杀死它,技术上应该在一个陷阱“…”退出。
有一个更好的方法来做到这一点,你已经发现它:三通。
只有,而不是只使用它为您的stdout,有一个发球台的stdout和一个stderr。你将如何做到这一点?进程替换和文件重定向:
command > >(tee stdout.log) 2> >(tee stderr.log >&2)
让我们分开来解释:
> >(..)
>(…)(过程替换)创建一个FIFO并让Tee监听。然后,它使用> (文件重定向)将命令的STDOUT重定向到您的第一个三通正在侦听的FIFO。
第二个同样的事情:
2> >(tee stderr.log >&2)
我们再次使用进程替换来创建一个从STDIN读取并将其转储到stderr.log中的tee进程。 tee在STDOUT上输出其输入,但由于其输入是我们的STDERR,因此我们要将tee的STDOUT重新定向到我们的STDERR。然后我们使用文件重定向将命令的STDERR重定向到FIFO的输入(tee的STDIN)。
过程替代是那些真正可爱的事情之一,作为选择bash作为你的shell,而不是sh(POSIX或Bourne)的奖励。
在sh,你必须手动做事情:
out="${TMPDIR:-/tmp}/out.$$" err="${TMPDIR:-/tmp}/err.$$"
mkfifo "$out" "$err"
trap 'rm "$out" "$err"' EXIT
tee stdout.log < "$out" &
tee stderr.log < "$err" >&2 &
command >"$out" 2>"$err"