fra*_*nkc 7 linux bash awk buffer
我正在尝试将时间戳应用于进程的标准输出。为了应用正确的时间戳,我尝试对过程进行unbuffer 标准输出。这适用于unbuffer但不符合stdbuf我的预期。考虑以下慢速打印脚本“ slowprint ”:
#!/bin/bash
if [ $# -ne 2 ]; then
echo "usage: ${0%%/*} <file> <delay in microseconds>"
exit 1
fi
DELAY=$2 perl -pe 'BEGIN{use Time::HiRes qw(usleep)} { usleep($ENV{DELAY}) }' $
Run Code Online (Sandbox Code Playgroud)
现在比较以下应用时间戳的尝试:
stdbuf -oL ./slowprint <(ls) 100000 |
awk '{ print strftime("%H:%M:%S"), $0; fflush(); }'
Run Code Online (Sandbox Code Playgroud)
对比
unbuffer ./slowprint <(ls) 100000 |
awk '{ print strftime("%H:%M:%S"), $0; fflush(); }'
Run Code Online (Sandbox Code Playgroud)
第二个对我有用,而第一个没有,尽管我希望他们做同样的事情。目前unbuffer不合适,因为它在某些情况下会吞下错误代码(我发布了一个关于该行为的单独问题)。
尝试annotate-output。它提供STDIN、STDOUT和STDERR的时间戳。
一个示例,用于对进程替换(一行)和不存在的文件wc进行行计数:bash
annotate-output wc -l <(echo foo) nosuchfile
Run Code Online (Sandbox Code Playgroud)
输出:
10:17:45 I: Started wc -l /dev/fd/63 nosuchfile
10:17:45 O: 1 /dev/fd/63
10:17:45 E: wc: nosuchfile: No such file or directory
10:17:45 O: 1 total
10:17:45 I: Finished with exitcode 1
Run Code Online (Sandbox Code Playgroud)