通过grep管道尾部输出两次

时间:2012-12-13 11:31:13

标签: bash shell unix grep tail

使用典型的Apache访问日志,您可以运行:

tail -f access_log | grep "127.0.0.1"

仅显示指定IP地址的日志(因为它们已创建)。

但是为什么第二次通过grep管道时会失败,以进一步限制结果?

例如,“。css”的简单排除:

tail -f access_log | grep "127.0.0.1" | grep -v ".css"

不会显示任何输出。

2 个答案:

答案 0 :(得分:45)

我认为这里的问题是第一个grep是缓冲输出,这意味着第二个grep在刷新缓冲区之前不会看到它。

尝试在第一个grep上添加--line-buffered选项:

tail -f access_log | grep --line-buffered "127.0.0.1" | grep -v ".css"

有关详细信息,请参阅"BashFAQ/009 -- What is buffering? Or, why does my command line produce no output: tail -f logfile | grep 'foo bar' | awk ..."

答案 1 :(得分:11)

这是缓冲的结果,当有足够的数据可用时,它将最终打印出来。

使用 Shawn Chin 建议的--line-buffered选项,或者如果stdbuf可用,您可以获得相同的效果:

tail -f access_log | stdbuf -oL grep "127.0.0.1" | grep -v ".css"