stderr 用法 linux,linux – 如何在使用“tee”时使用管道将stderr写入文件?

我假设你仍然看到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"

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值