前言
        在网络通信中,当IP层需要传输的数据包大小超过数据链路层的MTU限制时,就必须进行分片处理。本文将完整解析IP分片的工作机制,包括分片字段的作用、如何减少分片,以及分片报文的组装原理。

IP报头解析请参考:子网划分核心原理 (网络原理1)-CSDN博客

        在上一期的IP报头解析文章中,我们遗留了几个关键字段未作详述,即16位标识符、3位标志位以及13位片偏移量。这些字段实际上与IP分片和组装机制紧密相关,本章将对此展开详尽讲解。

一、什么是分片技术?

        由于物理介质等因素的限制,数据链路层规定从上层接收下来的完整报文大小不超过MTU(最大的传送单元),标准通常是1500字节就像寄包裹时不能超过1kg,需要我们分成小块寄

        如果从IP层传下来的超过MTU就需要分片发送。到了对端IP层会再进行组装。

        分片并不是一件好事,分片会增加丢包率——任意一个分片丢失都会导致整个报文失效。举个例子,假设报文的丢包率为1%,而一个报文被分成10份。要保证每一个报文都收到,才算不丢包,那么丢包率就变为1-99%^10,最后丢包率变为10%左右。

        所以分片和组装不是主流,是被迫为之,不是“原罪”。既然分片有显著弊端,如何减少?关键在哪一层控制?

        为什么说IP分片是被迫为之,传输层并不关心报文大小,只管将数据传给网络层,最终必须交付给对端传输层。而数据链路层的标准是不能超过1500字节,那么网络层夹在中间就很为难,需要自己解决这个问题,所以有了分片技术,在IP层分片交付到对端IP层在进行组装。分片技术的分与组均由网络层独立完成,与其他层解耦。

        所以要减少分片,即IP层的工作。那么就要从数据链路层的下手。

        怎么控制传输层数据量减少分片?MTU为1500字节,去掉IP报头20字节,那么从传输层传输下来的报文就要控制在1480字节以下。去掉传输层报头20字节,那么从发送缓存区取的报文就要控制在1460字节(称为MSS 最大段尺寸)以下。

        而数据发送多少又跟滑动窗口有关。滑动窗口里面的数据是分段发送的,而不是大块数据一次性发送,就是在控制数据发送量减少分片。

关于滑动窗口讲解:TCP协议可靠性设计的核心机制与底层逻辑-CSDN博客

注意:不同链路层有自己的 MTU,网络层需要兼容。

二、IP报头分片字段作用:

  • 16位标识:相同报文分出来的分片包标识相同,不同报文及它们的分片包不同。该字段是用来把分片包分类的。
  • 3位标志:
    • 第1位:未来功能扩展是使用。
    • 第2位:是否禁止分片(1表示禁止分片,被禁止分片的报文超过MTU直接丢包),通常都是设位0。
    • 第3位:更多分片。表示是否有更多分片,1表是有更多分片,0表示最后一分片。
  • 13位片偏移:表示当前分片包在第一个分片包的相对偏移位置。

三、如何分片和组装?

接下来讲解分片是如何组装的,理解如何组装,如何分片自然就能理解。

首先需要甄别出是否是分片报文?

        看3位标志的第三位,如果是1,那么它100%是分片报文。如果是0我们还不能确定,需要继续看13位片偏移,如果不为0则就是分片报文(而且是最后一片)。对立的,如果3位标第3位为0,且13位片偏移为0则不是分片报文。

        确定它是分片报文后,通过16位标识把它分类(相同报文的放在一起)。

怎么判断分片报文是否已经收全了?(或是否有丢失?)

划分为三种情况检测,第一片,中间片,最后一片。

  • 如果有13位片偏移为0的分片报文,则第一片没有丢失。
  • 3位标志的第三位,如果是0的分片报文,则最后一片没有丢失。
  • 判断中间片是否丢失可以把所有分片报文按13位片偏移排序(升序),13位片偏移+自己的报文长度就是下一片的13位片偏移,如果找不到对应的片,那就是丢失了。

如何组装?

        按13位片偏移升序排序后直接拼接就好。

非常感谢您能耐心读完这篇文章。倘若您从中有所收获,还望多多支持呀!74c0781738354c71be3d62e05688fecc.png

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[GESP202306 四级] 2023年6月GESP C++四级上机题超详细题解,附带讲解视频!

本文为2023年6月GESP C四级的上机题目的详细题解!觉得写的不错或者有帮助可以点个赞啦! (第一次讲解视频,有问题可以指出,不足之处也可以指出) 目录 题目一讲解视频: 题目二讲解视频: 题目一: 幸运数 题目大意: …

内网穿透 FRP 配置指南

关键词:内网穿透、FRP配置、frps、frpc、远程访问、自建服务器、反向代理、TCP转发、HTTP转发 在开发或部署项目时,我们经常遇到内网设备无法被公网访问的问题,例如你想从外网访问你家里的 NAS、远程调试开发板,或是访问本地测试环…

SpringBoot 信用卡检测、OpenAI gym、OCR结合、DICOM图形处理、知识图谱、农业害虫识别实战

信用卡欺诈检测通常使用公开数据集 数据准备与预处理 信用卡欺诈检测通常使用公开数据集如Kaggle的信用卡交易数据集。数据预处理包括处理缺失值、标准化数值特征、处理类别特征。在Spring Boot中,可以使用pandas或sklearn进行数据预处理。 // 示例:使用Spring Boot读取CS…

使用 Docker 部署 Golang 程序

Docker 是部署 Golang 应用程序的绝佳方式,它可以确保环境一致性并简化部署流程。以下是完整的指南: 1. 准备 Golang 应用程序 首先确保你的 Go 应用程序可以正常构建和运行。一个简单的示例 main.go: package mainimport ("fmt""net/http" )func ha…

从零开始的CAD|CAE开发: LBM源码实现分享

起因:上期我们写了流体仿真的经典案例: 通过LBM,模拟计算涡流的形成,当时承诺: 只要验证通过,就把代码开源出来;ok.验证通过了,那么我也就将代码全都贴出来代码开源并贴出:public class LidDrivenCavityFlow : IDisposable{public LidDrivenCavityFlow(int width 200, int hei…

仓库管理系统-17-前端之物品类型管理

文章目录 1 表设计(goodstype) 2 后端代码 2.1 Goodstype.java 2.2 GoodstypeMapper.java 2.3 GoodstypeService.java 2.4 GoodstypeServiceImpl.java 2.5 GoodstypeController.java 3 前端代码 3.1 goodstype/GoodstypeManage.vue 3.2 添加菜单 3.3 页面显示 1、goodstype表设…

共识算法深度解析:PoS/DPoS/PBFT对比与Python实现

目录 共识算法深度解析:PoS/DPoS/PBFT对比与Python实现 1. 引言:区块链共识的核心挑战 2. 共识算法基础 2.1 核心设计维度 2.2 关键评估指标 3. PoS(权益证明)原理与实现 3.1 核心机制 3.2 Python实现 4. DPoS(委托权益证明)原理与实现 4.1 核心机制 4.2 Python实现 5. P…

3.JVM,JRE和JDK的关系是什么

3.JVM,JRE和JDK的关系是什么 1.JDK(Java Development Kit),是功能齐全的Java SDK,包含JRE和一些开发工具(比如java.exe,运行工具javac.exe编译工具,生成.class文件,javaw.exe,大多用…

深度学习技术发展思考笔记 || 一项新技术的出现,往往是为了解决先前范式中所暴露出的特定局限

深度学习领域的技术演进,遵循着一个以问题为导向的迭代规律。一项新技术的出现,往往是为了解决先前范式中所暴露出的特定局限。若将这些新技术看作是针对某个问题的“解决方案”,便能勾勒出一条清晰的技术发展脉络。 例如,传统的前…

Promise的reject处理: then的第二个回调 与 catch回调 笔记250804

Promise的reject处理: then的第二个回调 与 catch回调 笔记250804 Promise 错误处理深度解析:then 的第二个回调 vs catch 在 JavaScript 的 Promise 链式调用中,错误处理有两种主要方式:.then() 的第二个回调函数和 .catch() 方法。这两种方…

Maven模块化开发与设计笔记

1. 模块化开发模块化开发是将大型应用程序拆分成多个小模块的过程,每个模块负责不同的功能。这有助于降低系统复杂性,提高代码的可维护性和可扩展性。2. 聚合模块聚合模块(父模块)用于组织和管理多个子模块。它定义了项目的全局配…

sqli-labs:Less-21关卡详细解析

1. 思路🚀 本关的SQL语句为: $sql"SELECT * FROM users WHERE username($cookee) LIMIT 0,1";注入类型:字符串型(单引号、括号包裹)、GET操作提示:参数需以)闭合关键参数:cookee p…

大模型+垂直场景:技术纵深、场景适配与合规治理全景图

大模型垂直场景:技术纵深、场景适配与合规治理全景图​​核心结论​:2025年大模型落地已进入“深水区”,技术价值需通过 ​领域纵深(Domain-Deep)​、数据闭环(Data-Driven)​、部署友好&#x…

Kotlin Daemon 简介

Kotlin Daemon 是 Kotlin 编译器的一个后台进程,旨在提高编译性能。它通过保持编译环境的状态来减少每次编译所需的启动时间,从而加快增量编译的速度。 Kotlin Daemon 的主要功能增量编译: 只编译自上次编译以来发生更改的文件,节…

鸿蒙南向开发 编写一个简单子系统

文章目录 前言给设备,编写一个简单子系统总结 一、前言 对于应用层的开发,搞了十几年,其实已经有点开发腻的感觉了,翻来覆去,就是调用api,页面实现,最多就再加个性能优化,但对底层…

超详细:2026年博士申请时间线

博士申请是一场持久战,需要提前规划。那么,如何科学安排2026年博士申请时间线?SCI论文发表的最佳时间节点是什么?今天给所有打算申博的同学们,详细解析下,每个时间节点的重点内容。2025年4月:是…

Python爬虫实战:研究tproxy代理工具,构建电商数据采集系统

1. 引言 1.1 研究背景 在大数据与人工智能技术快速发展的背景下,网络数据已成为企业决策、学术研究、舆情监控的核心资源。据 Statista 统计,2024 年全球互联网数据总量突破 180ZB,其中 80% 为非结构化数据,需通过爬虫技术提取与转化。Python 凭借其简洁语法与丰富的爬虫…

HighgoDB查询慢SQL和阻塞SQL

文章目录环境文档用途详细信息环境 系统平台:N/A 版本:6.0,5.6.5,5.6.4,5.6.3,5.6.1,4.5.2,4.5,4.3.4.9,4.3.4.8,4.3.4.7,4.3.4.6,4.3.4.5,4.3.4.4,4.3.4.3,4.3.4.2,4.3.4,4.7.8,4.7.7,4.7.6,4.7.5,4.3.2 文档用途 本文介绍了如何对数据库日志进行分析…

day15 SPI

1串行外设接口概述1.1基本概念SPI(串行外设接口)是一种高速、全双工、同步的串行通信协议。串行外设接口一般是需要4根线来进行通信(NSS、MISO、MOSI、SCK),但是如果打算实现单向通信(最少3根线&#xff09…

阿里云微服务引擎 MSE 及 API 网关 2025 年 7 月产品动态

点击此处,了解微服务引擎 MSE 产品详情。