首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >tcpdump -带有管道的实时dns记录器

tcpdump -带有管道的实时dns记录器
EN

Unix & Linux用户
提问于 2018-07-17 18:13:20
回答 1查看 1.1K关注 0票数 2

我想在stdout上的tcpdump实时获得DNS A记录。

代码语言:javascript
复制
tcpdump -i any dst port 53 | awk '/ A\? / {u = NF - 1; print $u}' | sed 's/.$//g'

从上面的行没有输出。Tcpdump似乎还在缓冲管道之类的东西。我也测试过-l --immediate-mode-U

下面的行输出正确(实时),但显然未经过滤(没有grep/awk):

代码语言:javascript
复制
tcpdump -i any dst port 53

如果我手动将它的输出行发送到上面的awk/sed命令,它们就会正常工作。

在Arch和Android8.1 (bash,tcpdump 4.9.2)上进行了测试。

问:如何使用管道/awk/sed实时获得tcpdump输出?

从2011年起就有一条老线索无法解决这个问题。如何实时处理/管道TCPDUMP输出

EN

回答 1

Unix & Linux用户

发布于 2018-07-17 20:09:11

试试这个变体:

代码语言:javascript
复制
tcpdump -l -i any dst port 53 | stdbuf -oL awk '/ A\? / {u = NF - 1; print $u}' | sed 's/.$//g'

您必须缓冲tcpdump输出的每一行,为此使用选项-l

来自man tcpdump

代码语言:javascript
复制
-l     Make stdout line buffered.  Useful if you want to see the data while capturing it.

为了使awk输出行缓冲,使用了斯德布夫

代码语言:javascript
复制
-o, --output=MODE  adjust standard output stream buffering
If MODE is 'L' the corresponding stream will be line buffered.
票数 2
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/456821

复制
相关文章

相似问题

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