Cra*_*cis 26 unix bash shell grep tail
使用典型的Apache访问日志,您可以运行:
tail -f access_log | grep "127.0.0.1"
Run Code Online (Sandbox Code Playgroud)
这只会显示指定IP地址的日志(因为它们已创建).
但是,为什么grep
在第二次管道时会失败,以进一步限制结果?
例如,".css"的简单排除:
tail -f access_log | grep "127.0.0.1" | grep -v ".css"
Run Code Online (Sandbox Code Playgroud)
不会显示任何输出.
Sha*_*hin 47
我相信这里的问题是第一个grep是缓冲输出,这意味着第二个grep在刷新缓冲区之前不会看到它.
尝试--line-buffered
在第一个grep上添加选项:
tail -f access_log | grep --line-buffered "127.0.0.1" | grep -v ".css"
Run Code Online (Sandbox Code Playgroud)
有关详细信息,请参阅"BashFAQ/009 - 什么是缓冲?或者,为什么我的命令行不产生输出:tail -f logfile | grep 'foo bar' | awk ...
"
Tho*_*hor 11
这是缓冲的结果,它将在有足够数据时最终打印.
使用Shawn Chin--line-buffered
建议的选项,或者如果可用,您可以获得相同的效果:stdbuf
tail -f access_log | stdbuf -oL grep "127.0.0.1" | grep -v ".css"
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
7252 次 |
最近记录: |