cut命令在偶遇grep后居然发生延迟是什么鬼?


1.先看这两条命令,每秒都有输出:
【top -d 1 | grep 'id' 】
【top -d 1 | cut -d ',' -f 4】
这说明, top、grep、cut是每秒都有输出。

2.但是,再看这条问题命令:
【top -d 1 | grep 'id' | cut -d ',' -f 4】
问题来了,要等大半天,然后是一次性输出一堆。
请问这是怎么回事啊?

测试OS:
Red hat 5.9
Ubuntu Server 14.04
Debian 7.8

linux运维 脚本语言 Linux linux编程 shell-script

Oo凡星oO 10 years, 6 months ago

因为输出被缓存了,GNU grep 有 --line-buffered 可以禁止,cut 似乎没有办法,改成这样试试:


 top -d 1 | grep --line-buffered 'id' | awk -F',' '{print $4}'

另外你也可以试试这里所说的 stdbuf unbuffer :
http://unix.stackexchange.com/questions/25372/turn-off-buffering-in-pi...

bondson answered 10 years, 6 months ago

Your Answer