本文讨论两个问题①IP数据报的首部②IP数据报的分片

TCP/IP模型分为五层,从上到下依次是应用层、传输层、网络层、数据链路层和物理层。

IP数据报是网络层的概念。

  • IP数据报的首部

版本号:0~3  共占4位,是IP协议的版本号,IPV4和IPV6,所以只能是0100、0110两个选项

首部长度:4~7 共占4位,共 有2的4次方,就是最多可以表示0~15个数,而IP数据报首部的固定部分都有20个字节了,所以0~15是不够用的,所以首部长度按4字节为一个单位。例如:首部长度0110=6,就是首部长度有6*4=24个字节。

服务类型Tos:8~15 共占8位,

总长度:16~31  共占16位,2的16次方=65536,也就是0~65535,IP分组的总长度,最长的IP分组是65535个字节。

生存时间TTL:63~70 共占8位,2的8次方=256,就是这个IP分组最多经过256个路由器。

协议:71~78 共占8位。该IP分组中装的是传输层哪个协议的数据包。6是TCP协议的,17是UDP协议的

首部校验和:79~94 共占16位。对首部错误的一个校验

标识、标志位、片偏移占32位,共4个字节,和IP数据报的分片有关。

  • 分片

分片的原因:在网络层,因为要向下层也就是数据链路层传输,而数据链路层帧有最大传输单元(Max Transport Unit  MTU)限制,超过这个值就得降数据报分组。

比如以太网的MTU是1500B,PPP(Point to Point Prootocol)的MTU是296B,FDDI(Fiber Distributing Data Interface 光纤分布式数据接口)的MTU是4352,令牌环的MTU是4464B。

如果数据报的长度大于MTU,就可以分片了。至于允许不允许分片,需要看IP数据报首部的标志位。

标识(ID):32~47 共占16位,IP分组的标识(ID),IP协议利用一个计数器,每产生一个IP分组加1,作为该分组的标识。

标志位:48~50 占3位,保留位、DF、MF。DF=Don't Fragment,DF=1时,不允许分片;DF=0时,允许分片。MF=1时,非最后一片;MF=0时,最后一片或者未分片。

这两位只有三种可能。10:不允许分片;01:允许分片,不是最后一片;00:允许分片,是最后一片。不存在11.

片偏移:占13位,这个分片在原IP分组中的相对位置,以分片的首字节表示。IP分组总长度是占16个字节,而片偏移占143个字节,所以片偏移是以(2的16次方)除以(2的13次方)=2的3次方=8字节为单位的。

举个例子:假设IP数据分组的长度是L,数据链路层的MTU是M,IP数据报首部的长度是20个字节(没有可选部分),每个分片都是按数据链路层可以传输的最大长度来切片的。那么:

每个分片中封装的数据:

d={向下取整【(M-20)/8】}*8

式子中20是首部数据长度,8:片偏移是以8字节为单位。

需要的总片数:

n=向上取整[(L-20)/d]

每片的片偏移字段取值:

Vi=(d/8)*(i-1) i=1,2,3...,n

每片的总长度字段:

li=d+20   i=1,2,。。。,n-1

li=L-(i-1)*d  i=n

把IP分组的标识作为每个分片的标识。

等IP数据报的所有分片到达接收端时,会按照片偏移把其重新组装起来。如果丢失了一片怎么办?接收方计算机会等待一段时间,如果还接收不到这个分片,就会把IP分组的所有分片全部丢掉。

思考一下:

接收端计算机怎么样才能唯一确定一个分片?

①源IP地址

②目的IP地址

③标识(ID)

④片偏移字段

⑤协议

欢迎大家指正~

IP分组和分片的更多相关文章

  1. tcp/ip 中的分组和分片

    osi 大家应该都知道osi七层模型吧,物理层 链路层 网络层 传输层 会话层 表示层 应用层ip 属于网络层,tcp 属于传输层,你可以把每一层想像成粽子的粽叶,包裹了七层的粽子最外面的就是物理层, ...

  2. TCP/IP协议原理与应用笔记26:网际协议(IP)之 分片(Fragmentation)

    1. 分片(Fragmentation) 适应在不同的MTU的物理网上传输. 备注: MTU:最大传输单元,Maximum Transmission Unit,它是指一种通信协议的某一层上面所能通过的 ...

  3. IP分组

    IP 分组为了更准确地讨论 I n t e r n e t协议处理,我们必须定义一些名词.图 显示了在不同的I n t e r n e t层之间传递数据时用来描述数据的名词.我们把传输协议交给 I P ...

  4. TCP/IP协议原理与应用笔记19:IP分组的交付和路由选择

    1. 引言: (1)互联网结构: 信息:IP分组(直接广播地址(Directed Broadcast Address),其指定了在一个特定网络中的"所有主机".) 节点:路由器.主 ...

  5. 转自:Tsihang 三层网络设备对于IP报文的分片和重组处理原理

    三层网络设备对于IP报文的分片和重组处理原理 对于网络分片,我一年前就想整理出来,虽然说网络上的资料很多,但是真正掌握精髓的除非真正做过分片程序,不然很难将协议栈整体联系起来理解.这篇文章,包括设计分 ...

  6. TCP层的分段和IP层的分片之间的关系 & MTU和MSS之间的关系 (转载)

    首先说明:数据报的分段和分片确实发生,分段发生在传输层,分片发生在网络层.但是对于分段来说,这是经常发生在UDP传输层协议上的情况,对于传输层使用TCP协议的通道来说,这种事情很少发生. 1,MTU( ...

  7. 原 TCP层的分段和IP层的分片之间的关系 & MTU和MSS之间的关系

    首先说明:数据报的分段和分片确实发生,分段发生在传输层,分片发生在网络层.但是对于分段来说,这是经常发生在UDP传输层协议上的情况,对于传输层使用TCP协议的通道来说,这种事情很少发生. 1,MTU( ...

  8. IP分组交付和转发

    1:交付 网络层监视底层物理网络对分组的处理过程叫做交付,分为直接交付和间接交付 1.1:直接交付 直接交付时,分组的终点是一台与交付着连接在同一个网络上的主机,发生在俩种情况下,分组的源点和终点都在 ...

  9. UDP用户数据报协议和IP分组

    UDP总体的封装格式例如以下: 以下是8字节UDP首部: 当IP层依据协议字段把UDP报文向上传送到UDP模块后,UDP模块再依据port号将数据发送到对应的进程中,以此实现进程到进程间的通信. 16 ...

随机推荐

  1. 03.python封装与解构

    封装与结构 基本概念 t1 = 1, 2 print(type(t1)) # 什么类型 t2 = (1, 2) print(type(t2)) Python等式右侧出现逗号分隔的多值的时候,就会将这几 ...

  2. vue 在实现关键字远程搜索时出现数据不准确的原因

    实现通过输入关键字查询项目, 页面搜索规则框部分 js部分 之前通过在data中定义一个变量,然后在methods中filterFn方法获取当时输入的值去后台请求数据,然后把请求的数据存放在state ...

  3. VC 2010 Express 学生版(中文版)

    Microsoft Visual C++ 2010 Express 学生版 下载传送门(提取码:r7sm) 如何安装 拿到压缩文件后,解压到桌面(别怕,安装完后这个文件夹是可以删除的). 在 &quo ...

  4. SpringCloud的Config应用

    一.简介 ***应用程序先注册到注册中心,在注册中心根据guli-config服务的名字找到配置中心,然后在配置中心根据配置从github加载基本配置. 二.配置中心(服务端,可以部署集群) 1.依赖 ...

  5. Lyft 宣布开源基础设施工具管理平台 Clutch!

    今天我们很高兴地宣布,Lyft 的基础设施工具可扩展 UI 和 API 平台clutch已开放源代码,clutch使工程团队能够构建.运行和维护用户友好的工作流,这些工作流还包含特定于域的安全机制和访 ...

  6. C语言字幕从外向中间汇聚

    演示数据中多个字符,从两端向中间移动,向中间汇聚 简单,粗暴,先上代码: Sleep()函数属于<windows.h>头文件中. sizeof()函数求右下标:数组内是数字时,求右下标要- ...

  7. GLPK下载安装

    GLPK下载安装 下载 wget http://ftp.gnu.org/gnu/glpk/glpk-4.65.tar.gz tar -zxvf glpk-4.65.tar.gz 安装 如果你有管理员权 ...

  8. 【vps】教你写一个属于自己的随机图API

    [vps]教你写一个自己的随机图API 前言 刚刚开始使用halo博客的时候,我就发现halo博客系统是可以使用随机图当背景的,所以也是使用了网上一些比较火的随机图API. 在上次发现了各种图片API ...

  9. 五天学完MySQL打卡挑战 day01

    明天继续上传学习笔记和练习的Word文档 晚安~

  10. DEEP LEARNING WITH PYTORCH: A 60 MINUTE BLITZ | TRAINING A CLASSIFIER

    你已经知道怎样定义神经网络,计算损失和更新网络权重.现在你可能会想, 那么,数据呢? 通常,当你需要解决有关图像.文本或音频数据的问题,你可以使用python标准库加载数据并转换为numpy arra ...