在Linux中,如何追踪TCP连接和网络数据包,如使用tcpdump或Wireshark?

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 在Linux中,如何追踪TCP连接和网络数据包,如使用tcpdump或Wireshark?

在Linux环境中,追踪TCP连接和网络数据包主要通过使用命令行工具tcpdump和图形化网络分析软件Wireshark来实现。以下是详细的操作步骤:

1. 使用 tcpdump

tcpdump 是一个强大的命令行网络抓包工具,用于实时捕获和分析网络流量。以下是如何使用 tcpdump 追踪TCP连接和数据包:

1. 基本用法
tcpdump [options] [expression]
  • 选项
  • -i interface:指定监听的网络接口(如 eth0enp0s3any)。
  • -n:禁止DNS反向解析,显示IP地址和端口号而非主机名和服务名。
  • -nn:同时禁止IP和端口的反向解析。
  • -v-vv:增加详细输出级别。
  • -w file:将捕获的数据包保存到指定的文件(.pcap 格式),以便用 Wireshark 等工具后续分析。
  • -c count:捕获指定数量的数据包后停止。
  • -B buffer_size:设置内核缓冲区大小,以适应高流量环境。
  • 表达式(filter expression):
  • tcp:仅捕获TCP协议的数据包。
  • port numberport number1,number2:筛选特定端口的流量。
  • host hostsrc hostdst host:按源或目的主机IP地址过滤。
  • net networksrc netdst net:按源或目的网络地址过滤。
  • tcp flags [flaglist]:筛选特定TCP标志位(如SYN、ACK、FIN等)的数据包。
  • 更多复杂的过滤规则请参阅 man tcpdump
2. 示例
  1. 监听所有TCP流量
sudo tcpdump -i any tcp
  1. 捕获特定端口(如80、443)的TCP数据包
sudo tcpdump -i any 'tcp and (port 80 or port 443)'
  1. 捕获特定主机间(如192.168.1.1与10.0.0.1)的TCP流量
sudo tcpdump -i any 'tcp and (host 192.168.1.1 and host 10.0.0.1)'
  1. 仅捕获TCP SYN和SYN-ACK包(追踪TCP连接建立过程):
sudo tcpdump -i any 'tcp[tcpflags] & (tcp-syn|tcp-ack) != 0'
  1. 将捕获的数据包保存到文件以供Wireshark分析
sudo tcpdump -i any -w capture_file.pcap tcp
2. 使用 Wireshark

Wireshark 是一款流行的跨平台图形化网络封包分析工具,提供了丰富的过滤、解析和数据显示功能。以下是如何使用 Wireshark 追踪TCP连接和数据包:

1. 基本步骤
  1. 启动 Wireshark
  • 打开Wireshark应用程序。
  • 选择要监听的网络接口。
  1. 开始捕获
  • 点击“开始”按钮(或键盘快捷键Ctrl+E)开始捕获网络流量。
  1. 设置过滤器
  • 在捕获过程中或捕获完成后,在主界面上方的“捕获过滤器”栏输入类似tcp的过滤条件来只显示TCP数据包。
  • 或者在捕获结束后,在下方的“显示过滤器”栏输入更详细的过滤条件(如端口、主机等)来筛选已捕获数据包。
  1. 分析数据包
  • 浏览数据包列表,双击某个数据包以查看其详细分层结构和协议字段。
  • 使用“Follow TCP Stream”功能(右键点击数据包,选择“Follow” → “TCP Stream”)来重组特定TCP连接的完整数据流。
  1. 导出或保存捕获结果
  • 若需保存分析结果,可选择“文件” → “保存”或“另存为”,保存为.pcap.pcapng格式。
2. 示例
  1. 追踪特定TCP连接
  • 捕获数据包后,使用“显示过滤器”(如 tcp.stream eq X,其中X是TCP流编号)筛选特定连接。
  • 或者直接在捕获过程中设置捕获过滤器,如 host 192.168.1.100 and port 80,仅捕获特定主机和端口的流量。
  1. 分析TCP序列号、窗口大小等细节
  • 双击一个TCP数据包,展开“TCP”协议层,查看序列号、确认号、窗口大小等字段,理解TCP连接的状态和数据传输过程。
  1. 检测网络异常
  • 使用Wireshark的内置分析功能(如“专家信息”面板)或手动检查数据包,识别重传、乱序、超时等TCP连接问题。

综上所述,tcpdump 和 Wireshark 相结合,能够有效地追踪TCP连接和网络数据包,帮助诊断网络问题、分析协议行为或安全审计。tcpdump 适用于快速抓包和初步过滤,而 Wireshark 提供了更直观、详尽的分析界面和高级功能,适用于深度分析和问题排查。

相关文章
|
7天前
|
编解码 异构计算
RT-DETR改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
RT-DETR改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
41 9
RT-DETR改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
|
7天前
|
计算机视觉
RT-DETR改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进RT-DETR颈部网络
RT-DETR改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进RT-DETR颈部网络
35 12
RT-DETR改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进RT-DETR颈部网络
|
8天前
|
计算机视觉
YOLOv11改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进v11颈部网络
YOLOv11改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进v11颈部网络
35 10
YOLOv11改进策略【Neck】| GFPN 超越BiFPN 通过跳层连接和跨尺度连接改进v11颈部网络
|
8天前
|
编解码 异构计算
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
30 7
YOLOv11改进策略【Neck】| BiFPN:双向特征金字塔网络-跨尺度连接和加权特征融合
|
4天前
|
Linux
SecureCRT连接Linux时乱码问题
本文详细介绍了在使用SecureCRT连接Linux服务器时出现乱码问题的解决方法,包括设置SecureCRT字符编码、检查和配置Linux服务器字符编码、调整终端设置等。通过这些方法,您可以有效解决SecureCRT连接Linux时的乱码问题,确保正常的终端显示和操作。希望本文能帮助您在实际操作中更好地解决类似问题,提高工作效率。
26 17
|
23天前
|
机器学习/深度学习 人工智能 搜索推荐
PaSa:字节跳动开源学术论文检索智能体,自动调用搜索引擎、浏览相关论文并追踪引文网络
PaSa 是字节跳动推出的基于强化学习的学术论文检索智能体,能够自动调用搜索引擎、阅读论文并追踪引文网络,帮助用户快速获取精准的学术文献。
184 15
|
2月前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
78 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
2月前
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
3月前
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
102 3
|
3月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。

热门文章

最新文章