Wireshark TS | 三谈 TCP 握手异常问题

news2025/1/18 14:44:23

前言

继续以一个实际案例来说下 TCP 握手问题,该数据包仍然来自于 Wireshark sharkfest 2017,一些简短但有趣的 TCP 跟踪文件中的又一个,或者说是最后一个了。可以说这些都是和 TCP 握手相关的连接问题,有兴趣的朋友可以私信,届时共享下相关数据包。


问题信息

数据包跟踪文件基本信息如下:

λ capinfos Sample03.pcapng
File name:           Sample03.pcapng
File type:           Wireshark/... - pcapng
File encapsulation:  Ethernet
File timestamp precision:  nanoseconds (9)
Packet size limit:   file hdr: (not set)
Packet size limit:   inferred: 58 bytes
Number of packets:   1102
File size:           116 kB
Data size:           956 kB
Capture duration:    69.469164000 seconds
First packet time:   2015-11-27 18:51:55.682798700
Last packet time:    2015-11-27 18:53:05.151962700
Data byte rate:      13 kBps
Data bit rate:       110 kbps
Average packet size: 867.71 bytes
Average packet rate: 15 packets/s
SHA256:              e0156ab381f1646742ff1400782334c8cfd78e64cdabd1368607806b61711df9
RIPEMD160:           eb423fa44c99618044fbadf6a2783eebcd03af44
SHA1:                d2b1059f35308520ba69e8cd29f3bcd7db998d8c
Strict time order:   True
Capture application: Sanitized by TraceWrangler v0.3.1 build 511
Number of interfaces in file: 1
Interface #0 info:
                     Name = eth0
                     Encapsulation = Ethernet (1 - ether)
                     Speed = 1000000000
                     Capture length = 65535
                     Time precision = nanoseconds (9)
                     Time ticks per second = 1000000000
                     Time resolution = 0x09
                     Number of stat entries = 0
                     Number of packets = 1102

λ

推测通过 Wireshark 捕获,snaplen 截断 58 字节长度,数据包捕获数量相对比较多 1102 个,捕获持续时间为 69.5 秒,平均速率 110 kbps, 并经过 TraceWrangler 匿名化软件所处理。

关于 TraceWrangler 匿名化软件简介,可以查看之前的文章《Wireshark 提示和技巧 | 如何匿名化数据包》

专家信息如下,相对数据包总数量来说,告警信息很少,仅仅 1 条 RST 以及 1 条 ACKed segment that wasn’t captured 信息,初步看起来挺正常的。

WHS-01


问题分析

数据包数量较多,就不完整展开,通过 tcp.stream 输出可知总共有 3 条 TCP Stream。

λ tshark -r Sample03.pcapng -T fields -e tcp.stream | sort | uniq
0
1
2

客户端 192.168.0.1 和服务器 10.10.10.1 交互的三条 TCP 流信息,其中 TCP Stream 2 稍显奇怪,仅仅只有 3 个数据包,同时这三条流中客户端 192.168.0.1 的源端口均为 24426 ,这是其中的一个疑点。

WHS-02

TCP Stream 0

首先从 TCP Stream 0 看起,整个遍历下来,是一次完整的 TCP 交互会话。其中在 Packet Details 中 TCP 会话完整性信息为 Conversation completeness:Complete,WITH_DATA(31) ,这说明 tcp.completeness 字段值为 31,如下:

  • 1 : SYN
  • 2 : SYN-ACK
  • 4 : ACK
  • 8 : DATA
  • 16 : FIN
  • 32 : RST

1 + 2 + 4 + 8 + 16 = 31 ,也就是 SYN + SYN-ACK + ACK + DATA + FIN 的值,说明 TCP Stream 0 是一个带有 Data 的完整 TCP 会话,从 TCP 三次握手,到中间数据传输,再到最后的 TCP 四次挥手。

关于 TCP 会话完整性分析介绍 以及 tcp.completeness 的显示过滤表达式使用方法,可见之前的文章 《Wireshark 提示和技巧 | TCP 会话完整性分析》

WHS-03

TCP Stream 1

在 TCP Stream 0 经历四次挥手后,客户端之后以同样源端口 24426 发起的 TCP Stream 1 发生了问题,服务器 10.10.10.1 回复了一个奇怪的 ACK,提示 TCP ACKed unseen segment 信息,客户端直接以 RST 结束了连接。

WHS-04

具体发生了什么? 转向 TCP 详细视图来一探究竟,分析如下:

  1. No.1040 - No.1043 为 TCP Stream 0 的四次挥手过程;

WHS-05

  1. 在 16s 之后,TCP Stream 1 客户端 No.1044 SYN 发出,服务器响应了一个 ACK=158049099,乍看之下感觉 Num 158049099 出现的莫名其妙,但实际需要注意的是,Wireshark 默认的是 TCP 相对序列号,而不是绝对序列号。关闭 TCP Relative sequence numbers 选项后的信息如下

WHS-06

之前的相对序列号 158049099 ,实际上是绝对序列号 2430890842 相对于 2272841743 的差值,而真正的这个 ACK Num 2430890842 的由来却是延续于 Stream 0

熟悉 TCP 四次挥手的同学应该会明白,在 TCP Stream 0 中 No.1040 也就是服务器首先发出的 FIN ,在 No.1043 服务器最后一个ACK 之后,服务器该连接会进入 TIME_WAIT 状态,也就是会等待 2MSL 的时间才最终 CLOSED,但是在这个 2MSL 的时间内,客户端正好又以同样的源端口 24426 发起了新连接,对于服务器来说自然是匹配到了老连接信息,因此回复一个 ACK=2430890842 的数据包,客户端在收到之后,判断是属于窗口之外的异常数据包,以一个 RST 结束 Stream 1。当然这是对客户端来说,同时这个 RST 实际上也结束了服务器 TCP Stream 0 的连接。

  1. 所以在 25s 之后,客户端 TCP Stream 2 No.1047 SYN 继续发出,虽然还是同样的源端口 24426 ,但是此时服务器的 TCP Sream 0 连接已经关闭再无相关信息了,所以 TCP Stream 2 完成了正常的又一次三次握手过程后,继续愉快的进行数据传输了。

WHS-07

No.1044 SYN 相距 No.1043 的时间仅为 16.49s ,仍处于 2MSL 时间范围内。虽然 No.1047 SYN 相距 No.1043 的时间为 42.45s,看起来仍是在 2MSL 时间范围内 ,为什么这次成功了?实际上是 No.1046 这个 RST 所带来的结果。

RFC 793 中规定 MSL 为 2 分钟,实际应用中常用的是 30 秒, 1 分钟和 2 分钟等, 2MSL 即两倍的 MSL 。

WHS-08


问题总结

关于 TCP TIME_WAIT 和 2MSL 的基础知识点,本篇并未详细展开,实际环境中 TIME_WAIT 状态对于服务器来说还是一个挺常见的现象,导致的原因也会有很多,后续有机会会再展开分析。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/44439.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Mybatis-Plus开发提速器mybatis-plus-generator-ui

前言 在基于Mybatis的开发模式中,很多开发者还会选择Mybatis-Plus来辅助功能开发,以此提高开发的效率。虽然Mybatis也有代码生成的工具,但Mybatis-Plus由于在Mybatis基础上做了一些调整,因此,常规的生成工具生成的代码…

【一文秒懂——SLF4j日志】

目录 1. SLF4j日志 2. 日志输出 1. SLF4j日志 在添加了spring-boot-starter的项目中,已经包含了SLF4j日志的相关依赖项。 在添加了lombok的项目中,可以在类上添加Slf4j注解,则lombok框架会在编译期在类中声明名为log的变量,通…

农民歌唱家大衣哥喜迎贵客,这三位明星一般人还真请不动

都知道农民歌唱家大衣哥家里热闹,不过大部分都是蹭流量拍视频的,真正的好朋友绝对没有几个。虽然说没有几个好朋友,但是也不代表一个没有,看看在大衣哥家里吃饭的三位,每一个都不是一般人物。 如今的大衣哥&#xff0c…

发现智能合约中的 bug 的 7 个方法

寻找智能合约bug可能是一项高回报的工作,而且它也保护了生态系统免受黑客攻击。我最近有幸采访了一位开发人员,他发现了一个价值 70 亿美元的错误,并因报告该错误而获得了 220 万美元的报酬。 在这篇文章中,我将详细介绍该开发人…

路由和流量控制

路由策略 控制路由,从而影响IP包的转发路径。 路由策略的主要功能有两个,1)过滤路由信息,2)修改路由属性值。 路由匹配工具 acl 只有基本acl(Basic ACL,编号为 2000-2999)可以匹配路由。ACL匹配路由时只能匹配路由的网络号,但无法匹配掩码长度。 [RouterA] acl n…

基于SpringBoot的会员制医疗预约服务管理信息系统

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SpringBoot 前端:Vue、HTML 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#…

使用CSS实现多种Noise噪点效果

在插画中添加噪点肌理可以营造出一种自然的氛围。噪点肌理可以用于塑造阴影、高光、深度以及更多细节,并优化插画质感,应用噪点肌理的方式在扁平插画中广受欢迎。 在前端开发过程中,我们也有可能遇到噪点插画风格的设计稿,应用基…

实验三-----数据库

一、实验目的 1.掌握SQL Server Management Studio中SQL 查询操作; 2.掌握SQL 的单表查询命令; 3.掌握SQL 的连接查询操作; 4.掌握SQL 的嵌套查询操作; 5.掌握SQL 的集合查询操作。 二、实验环境 1.实验室名称&…

Nevron 3DChart创建有吸引力的3D和2D图表

Nevron 3DChart创建有吸引力的3D和2D图表 3DChart使用OpenGL 3D图形引擎创建复杂的2D和3D图表和图形,这些图表和图形可以包含静止或动画图像。3DChart包括用于生成图表模板的独立应用程序和ASP服务器配置实用程序。该组件还包括一个专门设计用于与3DChart集成的工具栏组件。用…

SignalR简介及实践指南

SigalR简介 ASP.NET Core SignalR 是一个开放源代码库,可用于简化向应用添加实时 Web 功能。 实时 Web 功能使服务器端代码能够将内容推送到客户端。 适合 SignalR 的候选项: 需要从服务器进行高频率更新的应用。 示例包括游戏、社交网络、投票、拍卖…

【LeetCode】No.102. Binary Tree Level Order Traversal -- Java Version

题目链接:https://leetcode.com/problems/binary-tree-level-order-traversal/ 1. 题目介绍(Binary Tree Level Order Traversal) Given the root of a binary tree, return the level order traversal of its nodes’ values. (i.e., from …

React Redux 中触发异步副作用

React Redux 中触发异步副作用 一些基本的配置(这里使用 toolkit)可以在这篇笔记中找到:react-redux 使用小结,这里不多赘述。 触发副作用主流的操作方式有两种: 组件内操作 适合只会在当前组件中触发的 API 操作 写…

企业数仓DQC数据质量管理实践篇

一.数据质量管理背景 以大数据平台的核心理念是构建于业务之上,用数据为业务创造价值。大数据平台、数据仓库的搭建之初,优先满足业务的使用需求,数据质量往往是被忽视的一环。但随着业务的逐渐稳定,数据质量越来越被人们所重视。…

2.1.3 运算放大器的参数以及选型、静态、交流技术指标

笔者电子信息专业硕士毕业,获得过多次电子设计大赛、大学生智能车、数学建模国奖,现就职于南京某半导体芯片公司,从事硬件研发,电路设计研究。对于学电子的小伙伴,深知入门的不易,特开次博客交流分享经验&a…

基于小脑模型神经网络轨迹跟踪matlab程序

1 CMAC概述 小脑模型神经网络(Cerebellar Model Articulation Controller,CMAC)是一种表达复杂非线性函数的表格查询型自适应神经网络,该网络可通过学习算法改变表格的内容,具有信息分类 存储的能力。 CMAC把系统的输入状态作为一个指针,把相…

Oracle-Autoupgrade方式升级19c

前言: Autoupgrade是Oracle 推出的自动升级工具,通过该工具可以将数据库升级为Oracle12.2之后的版本,工具支持升级前的检查、升级问题修复、一键式自动升级以及升级后的问题修复,极大的简化数据库的升级步骤。 支持的目标升级版本: Oracle D…

用 Java 实现爬虫 (爬取本地html中的人物信息并可视化人物关系)

目录 爬虫简介 常用的工具框架 selenium Jsoup Jsoup介绍 Jsoup的主要功能如下: HTML 相关知识 通过Jsoup元素获取 案例 爬取本地html中的角色信息 HtmlParseUtil 可以利用relation-graph 将人物关系可视化 使用爬虫要注意 查看网站的爬虫协议 爬虫简介…

面试:ANR原因及排查

ANR原因 1、CPU满负荷,I/O阻塞 2、内存不足,系统分配给一个应用的内存是有上限的,长期处于内存紧张,会导致频繁内存交换,进而导致应用的一些操作超时。自己内存泄漏或者其他应用占用的大量内存 3、四大组件ANR 4、…

字符串压缩(一)之ZSTD

一、zstd压缩与解压 ZSTD_compress属于ZSTD的Simple API范畴,只有压缩级别可以设置。 ZSTD_compress函数原型如下: size_t ZSTD_compress(void* dst, size_t dstCapacity, const void* src, size_t srcSize, int compressionLevel) ZSTD_decompress函数原…

Mysql replace into

CREATE TABLE t (id int(11) NOT NULL AUTO_INCREMENT,age int(11) DEFAULT NULL,msg varchar(10) DEFAULT NULL,PRIMARY KEY (id),UNIQUE KEY uniq_age (age) ) ENGINEInnoDB DEFAULT CHARSETutf8;insert into t (age, msg) values (1,aaa),(2,bbb),(3,ccc);id 为自增主键、ag…