首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我怎样才能实时地发现一些连续的日志和grep单词呢?

我怎样才能实时地发现一些连续的日志和grep单词呢?
EN

Stack Overflow用户
提问于 2016-12-01 17:30:53
回答 1查看 148关注 0票数 1

在Linux中,我想监视一些工具的输出,例如dbus- monitor的输出。希望能对其输出中的一些特殊关键词进行统计,然后使用关键字作为其他程序的输入参数。就像下面,但不是很好。

代码语言:javascript
复制
dbus-monitor --system > d.log &
var=`cat d.log | grep some-key-word`
my_script.sh $var

我希望能实时监控输出流,而不是从一开始就对整个日志进行测试。只是为了阻止它的最新变化。例如,dmesg提供了一个选项dmesg -w,它满足了我的需要。

代码语言:javascript
复制
 -w, --follow                wait for new messages

那么如何制作这样的剧本呢?禁止最新的新输出,并持续使用它。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-01 17:53:24

不要使用cat,而是使用tail -F <file> | grep <something>。该选项使尾部等待并输出所有传入数据。很可能,您还需要用stdbuf -oL修改标准流的缓冲模式(默认情况下,stdout是完全缓冲的,这意味着每隔几千字节就会将数据写入文件中,而不是在每一行之后)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40916893

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档