您的位置:首页 > 娱乐 > 八卦 > 计算机网络之TCP序号,确认序号和报文传输时间

计算机网络之TCP序号,确认序号和报文传输时间

2024/12/23 3:32:00 来源:https://blog.csdn.net/qq_73509351/article/details/141272363  浏览:    关键词:计算机网络之TCP序号,确认序号和报文传输时间

开篇提示

        本篇适合于了解基础知识,进行扩展提高的使用,附带考研习题以及解析。

TCP序号和确认序号的区别

        TCP首部中有序号和确认序号,他们都是4个字节(4B),且在数据传输中有很重要的意义,那么两者的含义和区别是什么呢?我们先看他们的定义。

        序号指的是本报文段所发送的数据的第一个字节的序号,确认号是期望收到对方下一个报文段的第一个数据字节的序号。在进行“三次握手”和数据传输的时候,序号一般用seq表示,确认号一般用ack表示。

        接下来,我们就从建立TCP连接,到数据传输,再到断开连接整个过程分析客户机和服务器中的TCP序号和确认号的变化。

        我们首先要清楚,不论是客户机还是服务器,他们一般都有序号和确认号,序号是描述自己的情况,确认号是描述对方的情况。序号x代表着“我在传递这次报文的时候,我的报文起始序号是x”,确认号y代表着“在你下次传递报文的时候,我希望你从你的序号y开始发送”

        所以,在一个TCP报文中,序号和确认号没有任何关系。

        好的,现在我们来看建立TCP连接的过程。

        下面是建立TCP连接的示意图:

        建立连接前,客户机和服务器都会获得初始序号,可见,A获得的初始序号为x,B获得的初始序号为y,我们发现,在未进行数据传输,只是进行建立连接的确立的情况下,ack增加了,事实上,确认建立连接SYN和断开连接FIN都会占用一个字节,我们只需要注意seq代表自身情况,ack代表对方情况即可。

        我们举一个中间传输信息的例子。

        如果A序号seq是301(自己这条内容会从301号开始发送),传输100B的有效荷载(实际就是数据),确认号ack是800(正常情况下,希望B从B的800开始发送)

        如果B正常收到,他发送的序号seq会是A的ack确认号,也就是800,它的确认号是A下次发送信息的开始,也就是301+100 = 401 ,他会希望A下次从A的序号401开始,如果B携带了100B的数据发送给了A,此时,A的序号是B的序号401,A的确认号是希望下次B从哪里开始发,800+100=900

        特殊情况一:如果B未携带数据只确认,则A的确认号仍为800

        特殊情况二:现A的序号为401,确认号为900,向B发送了120B的数据,但是,数据丢失

        B的序号为A的确认号(A希望他这么做),但由于B尚未收到A的信息,他会仍然希望A从401号发送数据,而不是521号

        在断开连接时,会进行四次挥手,下面是断开TCP连接的示意图:

与序号和序列号相关的题目一般是给出seq和ack,继续推在传输数据后的seq和ack,只需要记住两者的含义即可。

        下面,我们来几道例题练练手。

习题一

1.SYN与FIN都会使ack+1

本题选A,C,首先A发送自身的序号X,B发送自身的序号Y,ack确认时确认对方的下次开始的序号。

2.seq与ack的关系

A的序号是200,确认字号201,B的序号一定是A的确认号,也就是201,B的确认号是A下次开始发送的开头,也就是200+2

3.seq和ack的关系

4.特殊情况

报文传输时间的计算

建立连接时间需要1.5个RTT

        对于服务器B,最长断开时间需要等待两个RTT+数据传输时间,最短时间是1.5个RTT,实际上,当A发送FIN后,B可以直接发送FIN,等待A确认后,即可直接关闭

        对于客户机A,它最长时间要1个RTT+数据传送时间+2MSL,MSL是最大报文段寿命,这是防止数据传送不到而引发问题,最短时间是1RTT+2MSL。

现在,我们来查看在TCP进行拥塞控制下数据传输所需要的时间。

        我们先提供一些关于拥塞控制的知识点。

1.MSS:最大段长,初始传输数据的速度为1MSS,不论是传输多少B,可以理解为是拥塞控制传输的基本单位

2.cwnd:当前的拥塞窗口,大小是多少倍的MSS来计算

3.ssthresh:门限,慢窗口阶段与拥塞避免阶段的分界点,当cwnd<ssthresh时,慢开始,当cwnd>ssthresh,拥塞避免

4.慢开始(启动)阶段:每次收到确认后,cwnd*2,如果慢开始cwnd*2后超过门限,会使得cwnd=ssthresh

5.拥塞避免阶段:每次收到确认后,cwnd+1

6.超时:时间过长后,超时,cwnd=1MSS,ssthresh变为超时时cwnd的一半

7.快恢复:连续收到3个多余的ACK(重复确认),ssthresh变为cwnd的一半,且cwnd = ssthresh,然后开始拥塞避免

8.如果同时出现接收窗口和拥塞窗口,实际窗口时两者中较小的一个

        现在,我们给出几个例题。

例题二

1.断开TCP连接时间

最短时间,C需要1RTT+2MSL,S需要1.5RTT,情况是当C请求断开时S也准备断开,D

2.慢启动和拥塞避免状态的选择

慢启动增长迅速,最短时间用慢启动,最长时间用拥塞避免,本题目中由于是最长时间,拥塞避免,需要24个RTT,D

3.接收窗口和拥塞窗口

两者都会影响cwnd,是两者中更小的那个决定的。接收缓存实际就是接收窗口的大小,他会随着存入数据而逐渐变小。在本题中,要求最小时间,慢启动状态,经过3RTT变为8KB,过程是1MSS

-2MSS-4MSS,更小的是拥塞窗口,因此,本题中接收窗口不会影响cwnd,B

慢启动门限为2KB,拥塞窗口为4KB,因此,在下个RTT中,拥塞窗口变为5KB,但是接收窗口是2KB,因此,最多发送2KB的数据

4.实例

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com