百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

《Wireshark TCP分析;异常流量 识别》

haoteby 2025-08-30 21:54 9 浏览

一、TCP 协议核心机制

在分析 TCP 流量前,需理解其核心机制:

  1. 三次握手:SYN → SYN+ACK → ACK
  2. 四次挥手:FIN → ACK → FIN → ACK
  3. 序列号(SEQ)与确认号(ACK):确保数据有序传输。
  4. 滑动窗口(Window Size):控制发送速率,避免拥塞。
  5. 重传机制:丢包时触发重传(Retransmission)。

二、Wireshark TCP 分析基础

1. 关键过滤表达式

过滤条件

功能

示例

tcp.flags.syn == 1

过滤 SYN 包(三次握手起始)

tcp.flags.syn == 1

tcp.flags.ack == 1

过滤 ACK 包(确认包)

tcp.flags.ack == 1

tcp.window_size == 0

过滤零窗口事件(接收方无法接收数据)

tcp.window_size == 0

tcp.analysis.retransmission

过滤 TCP 重传包

tcp.analysis.retransmission

tcp.analysis.flags

过滤异常标志位(如 RST、FIN)

tcp.analysis.flags

2. 关键分析面板

  • Packet Details 面板:查看 TCP 头部字段(源/目的端口、序列号、确认号、标志位)。分析 TCP 选项(如 MSS、Timestamps)。
  • TCP Stream GraphsRound Trip Time (RTT):分析往返延迟。Throughput:观察吞吐量变化。Window Size:检测窗口大小波动(如零窗口)。
  • Statistics 菜单TCP Stream Graphs:生成可视化图表。Conversations:统计 TCP 会话流量分布。

三、异常流量识别与分析

1. TCP 重传(Retransmission)

原因

  • 网络丢包(如带宽不足、链路不稳定)。
  • 服务器响应慢(如高负载、死锁)。

Wireshark 过滤

tcp.analysis.retransmission

分析步骤

  1. 定位重传包的时间点和序列号。
  2. 检查对应数据包的 RTT(右键 → TCP → Round Trip Time)。
  3. 若多个重传包集中在某一时间段,可能为网络拥塞或服务器故障。

案例

# 过滤 HTTP GET 请求的重传包
http.request.method == "GET" && tcp.analysis.retransmission

2. TCP 零窗口(Zero Window)

原因

  • 接收方处理能力不足(如 CPU/内存过载)。
  • 接收缓冲区满,无法接收更多数据。

Wireshark 过滤

tcp.window_size == 0

分析步骤

  1. 查看零窗口事件前后的流量模式。
  2. 检查接收方性能指标(如 CPU 使用率、内存占用)。
  3. 若持续出现零窗口,可能需优化接收方性能或调整发送速率。

3. TCP 乱序(Out-of-Order)

原因

  • 网络路径不稳定(如多路径路由导致包顺序混乱)。
  • 数据包经过不同延迟的链路。

Wireshark 过滤

tcp.analysis.out_of_order

分析步骤

  1. 观察乱序包的序列号是否连续。
  2. 若少量乱序,TCP 会自动重排;若频繁发生,可能影响应用性能。

4. TCP RST(Reset)

原因

  • 异常关闭连接(如客户端/服务器崩溃)。
  • 防火墙或安全设备拦截请求。

Wireshark 过滤

tcp.flags.reset == 1

分析步骤

  1. 检查 RST 包的发送方(客户端或服务器)。
  2. 若 RST 包伴随 SYN 包,可能为防火墙拦截(如端口未开放)。

5. 异常端口与协议行为

场景

  • 扫描行为(如 SYN 扫描、FIN 扫描)。
  • 非标准端口上的异常流量。

Wireshark 过滤

# 过滤 SYN 扫描(大量 SYN 包无后续 ACK)
tcp.flags.syn == 1 && tcp.analysis.flags

四、实战案例:识别 DDoS 攻击

场景:某 Web 服务器遭受 SYN Flood 攻击,需通过 Wireshark 分析流量特征。

步骤 1:捕获流量

tcpdump -i eth0 -w ddos_capture.pcap port 80

步骤 2:过滤 SYN 包

tcp.flags.syn == 1 && tcp.flags.ack == 0

步骤 3:分析攻击特征

  1. 异常 SYN 包数量:短时间内大量 SYN 包来自单一或分散 IP。
  2. 无后续 ACK:SYN 包未完成三次握手(半连接攻击)。
  3. 源 IP 伪造:通过 ip.src 过滤发现大量伪造 IP。

结论:确认为 SYN Flood 攻击,需启用防火墙规则过滤异常流量。


五、总结与提升建议

  1. 基础能力
  • 熟练使用 TCP 过滤器和统计工具(如 tcp.analysis)。
  • 理解重传、零窗口、乱序等异常的根源。
  1. 进阶技能
  • 结合 tshark 命令行工具批量分析日志(如统计重传率)。
  • 使用 Wireshark 的专家信息(Analyze → Expert Info)自动化标记问题。
  1. 工具扩展
  • Bro/Zeek:网络流量分析框架,生成详细日志。
  • Suricata:开源 IDS/IPS,实时检测异常流量。

通过系统化学习和大量实践,您将能够快速定位网络问题并制定优化策略!

相关推荐

软考在即,不如来快速复习吧_软考百度贴吧

5.29号就要考试的小伙伴方不方,不方的都是学霸!每天被工作压得喘不过气的浪孩只能临阵磨枪了。先来看看软件设计师的分数分布吧,知己知彼才能百战不殆嘛...

数据类型、运算符与表达式_数据类型,运算符与表达式的关系

在C语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。一、C中的类型可分为以下几种:1、基本类型:它们是算术类型,...

计算机组成原理复习要点(复习必过)

计算机组成原理复习要点一、...

2018年下半年网络工程师上午试题_2018年网络工程师上半年真题答案详解

2018下半年网络工程师上午试题分析与解答试题(1)采用n位补码(包含一个符号位)表示数据,可以直接表示数值_(1)。试题分析采用n位补码(包含一个符号位)表示数据时,用1位(最高位)表示数的符...

轻松办公-OfficeExcel函数精解(二十二)

轻松办公-OfficeExcel函数精解(二十二)1、...

企业无码药品快速上传操作指南(上)

根据国家医保局等四部门发布的《关于加强药品追溯码在医疗保障和工伤保险领域采集应用的通知》,自2025年7月1日起,医保定点医药机构在销售药品时必须扫描药品追溯码方可进行医保基金结算。对于2025年7月...

C/C++编程知识:整型数据在内存中的存储!讲解+示例

1.整型的归类charshortint...

1.2 计算机内信息的表示与存储_计算机中的信息存储

1.2计算机内信息的表示与存储上一节介绍了计算机发展及计算机简单的工作原理,引入了二进制的概念,讲解了十进制与二进制之间的转换关系。本节将进一步介绍如何用二进制表示现实世界的事物。计算机内部的程序和...

Bit Fiddle for Mac(字符进制转换工具) v1.4激活版

是否曾经想知道1的二进制补码写成十六进制数字是什么?还是需要快速的ASCII表?BitFiddle可以帮助您!BitFiddlemac破解版是一款不同进制之间进行数值转换的工具,这款软件能够将数...

零基础学C语言(4):基本数据类型——整型

上一节我们用如何用程序写一个计算器的例子,延伸到为啥会有数据类型、变量和常量的存在,并介绍了赋值和等于的区别。从这节开始详细分析这三个概念,从基本数据类型的整型开始,不多比比,直接上主菜。BOOL型上...

C语言-自运算、位运算、取反运算_c的位运算符

①自加自减运算...

第十一节课 原码 反码 奇偶校验码

大家好,我是电器电。今日我们先来介绍一下原码:在生活中正数和负数之分正数用十表示,负数用一表示。但在数字设备中机器不会识别正负号所以会在二进制码的最高位用0表示正,用1表示负。如(+105)原=011...

学习永远不晚 C语言试题及答案_学习永远不晚 C语言试题及答案解析

、单项选择题(本大题共20题,每题2分,共40分)1、以下不是C语言的特点的是(B)A、C语言简洁、紧凑B、能够编制出功能复杂的程序C、C语言可以直接对硬件进行操作D、C语言移植性好2...

整型的范围为什么是-32768 至 32767

初学PLC者都会有一个问题比较困扰,为什么PLC中整型数的范围是-32768~32767?直接回答就是因为计算机内表示数值使用的是补码,而不是原码,所以你才有这样的困扰。所谓原码就是这个数本身的二进制...

基础中的基础,不得不看的数字电路题目

1)10110010反码是(),补码是()。(填空)解析:本题考查数字电路中最基础的码制知识。...