【问题标题】:How should an mDNS server handle a reverse-mDNS request?mDNS 服务器应该如何处理反向 mDNS 请求?
【发布时间】:2014-04-19 02:25:20
【问题描述】:

首先,一些背景知识:avahid 在我的嵌入式 Linux 设备上给我造成了问题(它有崩溃的错误,看起来似乎不会很快修复),我只需要最少的 mDNS 功能(即足以让某人在 Mac 或 PC 上可以执行“ping6 mydevicename.local。”并将该主机名解析到我的设备),所以我编写了自己的极简 mDNS 服务器(在 C 中),它基本上只监听多播 DNS 数据包并用必要的 mDNS 记录。

这主要是有效的 - 特别是,从 Mac 上进行上述 ping6 测试可以立即解决并且效果很好。

然而,我注意到,如果我从 Linux 机器执行 ping6,它只能工作。特别是:

  • Linux 客户端解析主机名大约需要 4 秒
  • 每个发送的 ping 数据包都会发生 4 秒延迟……也就是说,ping6 程序不是每秒发送一个 ping,而是每 4 秒发送一个 ping。 (它确实得到了预期的乒乓球)
  • 当我在嵌入式 Linux 设备上运行 avahid 时没有出现此问题,因此我认为该行为一定是由于我的新 mDNS 服务器执行的操作不正确造成的。
  • 发生这种情况时,我的 mDNS 服务器会从客户端获取反向 mDNS 数据包,如下调试输出所示:

[…]

RECEIVED 90 IPv6 BYTES FROM [fe80::21c:abff:fe00:a60] on s6#2 (sock=6)
--- Received IPv6 Data (90 bytes): -------------------------------------
0000: .............3.2 [00 00 00 00 00 01 00 00 00 00 00 00 01 33 01 32]
0016: .6.4.2.0.e.f.f.f [01 36 01 34 01 32 01 30 01 65 01 66 01 66 01 66]
0032: .b.2.0.6.2.0.0.0 [01 62 01 32 01 30 01 36 01 32 01 30 01 30 01 30]
0048: .0.0.0.0.0.0.0.0 [01 30 01 30 01 30 01 30 01 30 01 30 01 30 01 30]
0064: .0.0.0.8.e.f.ip6 [01 30 01 30 01 30 01 38 01 65 01 66 03 69 70 36]
0080: .arpa.....       [04 61 72 70 61 00 00 0c 00 01]
HandlemDNSRequest:  transID=0 flags=0 numQuestions=1 numAnswers=0 numAuthorityRRs=0 numAdditionalRRs=0
Ooh, a reverse-mDNS request for [3.2.6.4.2.0.e.f.f.f.b.2.0.6.2.0.0.0.0.0.0.0.0.0.0.0.0.0.0.8.e.f.ip6.arpa] scope=3

所以我的问题是:

  • 每次程序尝试使用我的 mDNS 服务器解析 mDNS 主机名时,什么会导致 Linux mDNS 主机名解析客户端软件(NSS-resolver?)延迟 4 秒?

  • 响应上述 mDNS 请求的适当方式是什么?我查看了 mDNS 和 DNS 规范,但找不到任何明确的要求。我尝试让它以通常的信息(主机名、IP 地址等)进行响应,但这并没有消除延迟。

  • 还有什么我可能做错的吗? (除了尝试推出我自己的 mDNS 服务器——但相信我,如果我觉得有更好的选择,我不会这样做;avahid 只是没有切芥末)

【问题讨论】:

    标签: linux dns mdns


    【解决方案1】:

    通过使用 nTap 设备和 WireShark 捕获由 Avahid 和我自己的程序生成的 mDNS 流量,我终于能够找出问题所在。由于 avahid 没有产生这个问题,因此 avahid 产生的响应可能是 Linux 正在寻找的响应。我更新了我的程序以生成类似的响应,从而消除了 5 秒的延迟。

    特别是,由 avahid 生成的反向 mDNS 响应仅包含 0 个查询和 1 个答案(主机名类型),如随附的 wireshark 屏幕截图所示。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-09-25
      • 2023-03-30
      • 1970-01-01
      • 2019-09-08
      相关资源
      最近更新 更多