使用典型的 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"
不会显示任何输出。
我相信这里的问题是第一个 grep 正在缓冲输出,这意味着第二个 grep 在刷新缓冲区之前不会看到它。
尝试添加--line-buffered
第一个 grep 上的选项:
tail -f access_log | grep --line-buffered "127.0.0.1" | grep -v ".css"
欲了解更多信息,请参阅“BashFAQ/009 -- 什么是缓冲?或者,为什么我的命令行不产生输出:tail -f logfile | grep 'foo bar' | awk ..."
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)