AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 46532
Accepted
Alnitak
Alnitak
Asked: 2009-07-28 07:14:14 +0800 CST2009-07-28 07:14:14 +0800 CST 2009-07-28 07:14:14 +0800 CST

更改与 tcpdump 中的端口关联的协议?

  • 772

继这个问题之后,我怎么知道tcpdump对特定端口使用特定的协议分析器?

我正在使用在端口 5053 上运行的测试服务器进行一些 DNS 开发,但我不知道如何判断tcpdump这是否真的是 DNS 流量。

我不能使用wireshark——数据包没有通过有GUI的机器。

domain-name-system tcpdump
  • 4 4 个回答
  • 1715 Views

4 个回答

  • Voted
  1. Best Answer
    bortzmeyer
    2009-07-28T07:28:26+08:002009-07-28T07:28:26+08:00

    tshark 是 Wireshark 软件包的一部分,是纯文本的。

    所以,tshark -d udp.port==5053,dns应该工作。

    • 6
  2. Dan Carley
    2009-07-28T10:12:41+08:002009-07-28T10:12:41+08:00

    有趣的问题。似乎应该可以通过以下选项访问它:

    -T  Force  packets  selected  by  "expression" to be interpreted the
        specified type.  Currently known  types  are  aodv  (Ad-hoc  On-
        demand Distance Vector protocol), cnfp (Cisco NetFlow protocol),
        rpc (Remote Procedure Call), rtp (Real-Time Applications  proto-
        col), rtcp (Real-Time Applications control protocol), snmp (Sim-
        ple Network Management Protocol), tftp  (Trivial  File  Transfer
        Protocol),  vat  (Visual  Audio Tool), and wb (distributed White
        Board).
    

    除了“域”显然不是一个有效的选项。我想如果您愿意的话,可以对 tcpdump 源代码进行一些小的修改。

    更新

    像这样。使用风险自负:

    diff -ru tcpdump-3.9.8/interface.h tcpdump-3.9.8_modified/interface.h
    --- tcpdump-3.9.8/interface.h   2007-06-14 02:03:20.000000000 +0100
    +++ tcpdump-3.9.8_modified/interface.h  2009-07-27 19:40:55.831913794 +0100
    @@ -74,6 +74,7 @@
     #define PT_CNFP                7       /* Cisco NetFlow protocol */
     #define PT_TFTP                8       /* trivial file transfer protocol */
     #define PT_AODV                9       /* Ad-hoc On-demand Distance Vector Protocol */
    +#define PT_DOMAIN              10      /* Domain Name Service */
    
     #ifndef min
     #define min(a,b) ((a)>(b)?(b):(a))
    diff -ru tcpdump-3.9.8/print-udp.c tcpdump-3.9.8_modified/print-udp.c
    --- tcpdump-3.9.8/print-udp.c   2007-06-14 02:03:21.000000000 +0100
    +++ tcpdump-3.9.8_modified/print-udp.c  2009-07-27 19:39:13.893442797 +0100
    @@ -520,6 +520,11 @@
                            tftp_print(cp, length);
                            break;
    
    +               case PT_DOMAIN:
    +                       udpipaddr_print(ip, sport, dport);
    +                       ns_print((const u_char *)(up + 1), length, 0);
    +                       break;
    +
                    case PT_AODV:
                            udpipaddr_print(ip, sport, dport);
                            aodv_print((const u_char *)(up + 1), length,
    diff -ru tcpdump-3.9.8/tcpdump.c tcpdump-3.9.8_modified/tcpdump.c
    --- tcpdump-3.9.8/tcpdump.c     2007-09-26 02:59:54.000000000 +0100
    +++ tcpdump-3.9.8_modified/tcpdump.c    2009-07-27 19:27:40.199449150 +0100
    @@ -718,6 +718,8 @@
                                    packettype = PT_TFTP;
                            else if (strcasecmp(optarg, "aodv") == 0)
                                    packettype = PT_AODV;
    +                       else if (strcasecmp(optarg, "domain") == 0)
    +                               packettype = PT_DOMAIN;
                            else
                                    error("unknown packet type `%s'", optarg);
                            break;
    
    • 5
  3. Devnull
    2009-07-28T07:27:21+08:002009-07-28T07:27:21+08:00

    可能对回答您的问题没有明确帮助,但您不需要 GUI 来运行wireshark。

    X11 通过 SSH 建立隧道将允许您远程运行完整的应用程序。它适用于 cygwin-x 或 openssh,具体取决于您在桌面上使用的是 windows 还是 linux。

    编辑:grawity 是正确的,它不是端口转发。

    • 1
  4. Marcin
    2009-07-28T09:44:51+08:002009-07-28T09:44:51+08:00

    或者您可以在两台主机之间放置一个 GUI 机器,然后在两个接口之间进行桥接。为此,我为自己建造了一台微型计算机,它有助于调试各种无法选择wireshark的安装(即路由器)

    • 0

相关问题

  • 可以任意注册名字到同一个公网IP吗?

  • Linux 绑定服务器为 DHCP Windows 客户端提供地址,但不为 DHCP Linux 客户端提供地址

  • 如何使用 Windows Server 解析 http 域名

  • 动态更新 /etc/resolv.conf 中列出的解析器

  • 内部名称解析

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve