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
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
7 回答5.4k 阅读
4 回答4.1k 阅读
2 回答5.9k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
2 回答860 阅读✓ 已解决
2 回答3.3k 阅读
1 回答1.1k 阅读✓ 已解决
因为输出被缓存了,GNU grep 有 --line-buffered 可以禁止,cut 似乎没有办法,改成这样试试:
另外你也可以试试这里所说的
stdbuf
和unbuffer
:http://unix.stackexchange.com/questions/25372/turn-off-buffering-in-pi...