“uniq”在管道传输时不是实时的

“uniq”在管道传输时不是实时的

当我跑步时

for i in {1..2000}; do sleep 0.1 && echo $(netstat -s | grep -i syns); done | uniq

我可以实时看到表情的$(netstat -s | grep -i syns)变化。

但是当我想修改管道的输出时:

for i in {1..2000}; do sleep 0.1 && echo $(netstat -s | grep -i syns); done | uniq | while read line; do echo $(date) $line; done

实时行为丢失。如何使用 的输出uniq进行进一步操作,特别是向每个输入行更改附加日期?

答案1

也许你只需要改变缓冲:

# buffering totally off
stdbuf -i0 -o0 -e0 command

# buffering per line only
stdbuf -oL -eL command

它在这里对我有用......你的结果可能会有所不同。如果它不起作用,请尝试将其放在不同的命令之前(不是 while 或 read,因为它们是 bash 内置命令)。

for i in {1..2000}; do
    sleep 0.1 && echo $(netstat -s | grep -i syns)
done \
| stdbuf -oL -eL uniq | while read line; do
    echo $(date) $line
done

相关内容