标签:无法 丢失 限制 数据 单元 set 过程 port 路由
则仅仅能有网络层来决定。TCP会丢包重传,可是UDP则不会,IP层是没有丢包重传机制的。
这个U D P长度是有冗余的。
I P数据报长度指的是数据报全长
(图3 - 1),因此U D P数据报长度是全长减去I P首部的长度
它还声明,
假设发送端已经计算了检验和,那么接收端必须检验接收到的检验和(如接收到检验
和不为0)。可是。很多系统没有遵守这一点,仅仅是在出口检验和选项被打开时才验证
接收到的检验和。
I P首部中包括的数据为分片和又一次组装提供了足够的信息。
除了最后一片外。其它每
个组成数据报的片都要把该比特置1。
片偏移字段指的是该片偏移原始数据报開始处的位置。
另外,当数据报被分片后。每一个片的总长度值要改为该片的长度值。
最后,标志字段中有一个比特称作“不分片”位。
假设将这一比特置1,I P将不正确数据报
进行分片。相反把数据报丢弃并发送一个I C M P差错报文(“须要进行分片但设置了不分片比
特”,见图6 - 3)给起始端。
在下一节我们将看到出现这个差错的样例。
当I P数据报被分片后,每一片都成为一个分组,具有自己的I P首部。并在选择路由时与
其它分组独立。这样,当数据报的这些片到达目的端时有可能会失序。可是在I P首部中有足
够的信息让接收端能正确组装这些数据报片。
虽然I P分片过程看起来是透明的,但有一点让人不想使用它:即使仅仅丢失一片数据也要重
传整个数据报。
为什么会发生这样的情况呢?由于I P层本身没有超时重传的机制——由更高层来
负责超时和重传(T C P有超时和重传机制,但U D P没有。
一些U D P应用程序本身也运行超时和
重传)。当来自T C P报文段的某一片丢失后,T C P在超时后会重发整个T C P报文段,该报文段对
应于一份I P数据报。没有办法仅仅重传数据报中的一个数据报片。其实。假设对数据报分片的
是中间路由器。而不是起始端系统,那么起始端系统就无法知道数据报是怎样被分片的。就这
个原因,常常要避免分片。
当I P数据报被分片后,t c p d u m p打印出其它的信息。首先,frag 26304(第3行和第4
行)和frag 26313(第5行和第6行)指的是I P首部中标识字段的值。
分片信息中的下一个数字。即第3行中位于冒号和@号之间的1 4 8 0,是除I P首部外的片长。
两份数据报第一片的长度均为1 4 8 0:U D P首部占8字节。用户数据占1 4 7 2字节(加上I P首部的
2 0字节分组长度正好为1 5 0 0字节)。第1份数据报的第2片(第4行)仅仅包括1字节数据—剩下
的用户数据。第2份数据报的第2片(第6行)包括剩下的2字节用户数据。
在分片时,除最后一片外,其它每一片中的数据部分(除I P首部外的其余部分)必须是8
字节的整数倍。在本例中,1 4 8 0是8的整数倍。
位于@符号后的数字是从数据报開始处计算的片偏移值。两份数据报第1片的偏移值均为0(第3行
和第5行),第2片的偏移值为1 4 8 0(第4行和第6行)。跟在偏移值后面的加号相应于I P首部中3 bit标志
字段中的“很多其它片”比特。
设置这一比特的目的是让接收端知道在什么时候完毕全部的分片组装。
最后。注意第4行和第6行(不是第1片)省略了协议名(U D P)、源port号和目的port号。
协议名是能够打印出来的。由于它在I P首部并被拷贝到各个片中。
可是,port号在U D P首部,
仅仅能在第1片中被发现。
须要重申的是。任
何运输层首部仅仅出如今第1片数据中。
一个分组能够是一个完整的I P数据报。
也能够是I P数据报的一个分片。
去除2 0字节的I P首部和8个字节的U D P首部。U D P数据报中用户数据的最长长度为
6 5 5 0 7字节。可是,大多数实现所提供的长度比这个最大值小。
标签:无法 丢失 限制 数据 单元 set 过程 port 路由
原文地址:http://www.cnblogs.com/zsychanpin/p/6795524.html