本文讨论两个问题①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. 初识python 之 smtplib 发送(dolphinscheduler任务监测)邮件

    需求 监测dolphinscheduler调度系统,任务执行异常情况.如有异常,则发送邮件通知. 处理思路 因DS本身自带的邮件发送功能,不能正常发送邮件. 故而,通过查询DS源数据表,获取当前任务执 ...

  2. docker查看容器的ip地址

    查看Docker的底层信息. docker inspect 会返回一个 JSON 文件记录着 Docker 容器的配置和状态信息 # 列出所有容器的IP地址docker inspect --forma ...

  3. 新增访客数量MR统计之NewInstallUserMapper中维度信息准备

    关注公众号:分享电脑学习回复"百度云盘" 可以免费获取所有学习文档的代码(不定期更新)云盘目录说明:tools目录是安装包res 目录是每一个课件对应的代码和资源等doc 目录是一 ...

  4. Yum安装Maven

    一.安装 wget http://repos.fedorapeople.org/repos/dchen/apache-maven/epel-apache-maven.repo -O /etc/yum. ...

  5. 服务限流 -- 自定义注解基于RateLimiter实现接口限流

    1. 令牌桶限流算法 令牌桶会以一个恒定的速率向固定容量大小桶中放入令牌,当有浏览来时取走一个或者多个令牌,当发生高并发情况下拿到令牌的执行业务逻辑,没有获取到令牌的就会丢弃获取服务降级处理,提示一个 ...

  6. 软件开发架构与网络之OSI七层协议(五层)

    本期内容概要 python回顾 软件开发架构 网络理论前瞻 osi七层协议(五层) 以太网协议 IP协议 port协议 交换机 路由器 局域网 广域网 TCP协议 三次握手 四次挥手 UDP协议 内容 ...

  7. ecos matlab版本安装

    官网链接 github地址 1.注意不仅要下载matlab版本,同时还要下载c版本,因为matlab版本缺少第三方软件,将两个版本解压缩后将c版本下的文件夹external,ecos_bb,inclu ...

  8. 【刷题-LeetCode】210. Course Schedule II

    Course Schedule II There are a total of n courses you have to take, labeled from 0 to n-1. Some cour ...

  9. Anaconda 创建 32位python虚拟环境

    Anaconda 创建 32位python虚拟环境 ​ 最近实习在做一个接口自动化数据上传的功能,因为数据是更新的,需要每次上传都查询数据库调用匹配,就不得不面对 python 连接 oracle . ...

  10. javascript的AMD规法--esl与requirejs浅介。

    AMD规范,全称是Asynchronous Module Definition,即异步模块加载机制.从它的规范描述页面看,AMD很短也很简单,但它却完整描述了模块的定义,依赖关系,引用关系以及加载机制 ...