Linux如何查看UDP报文?

核心工具及操作步骤

tcpdump(命令行抓包)

  • 安装与基础命令

    sudo apt install tcpdump  # Debian/Ubuntu
    sudo yum install tcpdump  # RHEL/CentOS
  • 捕获UDP报文

    sudo tcpdump -i any udp -vv -X
    • -i any:监听所有网卡
    • udp:过滤UDP协议
    • -vv:显示详细报文头
    • -X:以HEX+ASCII格式输出内容(显示报文负载)
  • 高级过滤
    指定端口和保存到文件:

    sudo tcpdump -i eth0 udp port 53 -w dns.pcap  # 抓取DNS请求(UDP 53端口)

    tcpdump -r dns.pcap回放文件。

Wireshark(图形化分析)

  • 安装
    sudo apt install wireshark  # Debian/Ubuntu
  • 操作流程
    1. 启动Wireshark:sudo wireshark
    2. 选择网卡(如eth0)
    3. 在过滤栏输入 udp 并回车
    4. 点击报文可查看各层详情(IP头、UDP头、负载数据)

nc (netcat) 测试UDP通信

  • 接收端(监听UDP 9999端口):
    nc -ul -p 9999 -v
  • 发送端
    echo "Hello UDP" | nc -u 127.0.0.1 9999
    • -u:启用UDP模式
    • -v:显示详细连接信息

ss(监控UDP连接状态)

查看活跃UDP连接:

ss -uap
  • -u:仅显示UDP
  • -a:所有连接
  • -p:显示关联进程

工具对比与选型建议

工具 适用场景 优势 局限
tcpdump 服务器环境快速抓包 低资源占用,支持复杂过滤 无图形界面
Wireshark 深度分析报文内容 可视化解析各协议层 需GUI环境
nc 简易UDP服务测试 快速验证通信 功能单一
ss 实时监控连接状态 显示进程信息 不展示报文内容

关键注意事项

  1. 权限要求
    抓包需root权限(使用sudo),否则会提示 no permission to capture
  2. 安全合规
    仅监控授权网络,禁止截获他人数据(违反《网络安全法》)。
  3. 性能影响
    高频抓包可能增加CPU负载,生产环境建议限速:

    sudo tcpdump -i eth0 -c 1000 udp  # 只抓1000个包
  4. 过滤技巧
    • 按IP过滤:tcpdump udp and host 192.168.1.100
    • 按范围端口:tcpdump udp portrange 10000-20000

典型应用场景

  • DNS问题排查
    sudo tcpdump -i any udp port 53
  • NTP服务调试
    sudo tcpdump -i eth0 udp port 123
  • 自定义UDP应用
    结合nc发送测试数据,用tcpdump验证负载内容。

掌握tcpdumpWireshark等工具的组合使用,可高效诊断UDP网络问题,优先通过命令行工具(如tcpdump)在服务器端捕获,再用Wireshark深度分析,始终遵循最小权限原则,避免非法监控。

引用说明参考Linux man手册(tcpdump(1)、nc(1)、ss(8))及Wireshark官方文档,符合网络调试最佳实践。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/8123.html

(0)
酷番叔酷番叔
上一篇 2025年7月21日 00:30
下一篇 2025年7月21日 00:39

相关推荐

  • Linux中如何打开ICC2工具?操作步骤与方法详解

    在Linux系统中,“打开icc2”通常指的是使用Intel oneAPI DPC++/C++ Compiler(简称icc2),这是Intel推出的高性能编译器,支持C++、DPC++(SYCL)等语言,常用于高性能计算、并行程序开发等领域,要正确“打开”(即安装并启用)icc2,需完成系统准备、安装、环境配……

    2025年9月21日
    1.3K00
  • Linux系统如何正确加载磁盘设备?

    Linux系统加载磁盘是一个涉及硬件识别、分区管理、文件系统创建及挂载配置的完整流程,其核心目的是将物理磁盘设备转化为系统可读写的存储单元,整个过程从硬件接入开始,经过内核识别、分区规划、格式化处理,最终通过挂载操作使磁盘数据在文件系统中可访问,同时支持开机自动加载,确保存储资源的持续可用,硬件连接与系统识别L……

    2025年10月5日
    11400
  • linux 如何安装jq工具

    jq 是一个轻量级、灵活的命令行 JSON 处理工具,专为 Linux/Unix 系统设计,它类似于 sed、awk、grep 等文本处理工具,但专门针对 JSON 数据格式,支持复杂的查询、过滤、转换和格式化操作,无论是解析 API 返回的 JSON 响应、提取配置文件中的特定字段,还是批量处理 JSON 数……

    2025年9月26日
    12000
  • 添加Surý旧版PPA安全可靠吗?

    在Linux系统上部署或维护PHP 5需要谨慎操作,因为PHP 5系列(包括5.6及更早版本)已于2018年12月正式结束官方支持,不再提供安全更新,这意味着继续使用可能存在严重的安全风险,以下是在Linux中管理PHP 5的详细指南,适用于必须兼容旧项目的特殊场景:PHP 5在Linux中的安装方法Ubunt……

    2025年7月15日
    12700
  • ARM设备运行Linux时如何安全退出?

    退出当前终端会话当需要结束命令行操作时:临时退出当前Shellexit或按快捷键 Ctrl + D效果:关闭当前终端窗口或返回上一级登录状态(不影响系统运行),终止正在运行的前台程序Ctrl + C # 强制终止当前进程退出图形界面(GUI)若设备运行桌面环境(如GNOME、KDE):通过系统菜单退出点击屏幕右……

    2025年7月26日
    11400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信