查看: 99520|回复: 138

[原创]TCP序列号和确认号详解

[复制链接]
发表于 2006-11-10 16:44:18 | 显示全部楼层 |阅读模式
TCP序列号和确认号详解

完整的PDF下载:

在网络分析中,读懂TCP序列号和确认号在的变化趋势,可以帮助我们学习TCP协议以及排查通讯故障,如通过查看序列号和确认号可以确定数据传输是否乱序。但我在查阅了当前很多资料后发现,它们大多只简单介绍了TCP通讯的过程,并没有对序列号和确认号进行详细介绍,结合实例的讲解就更没有了。近段时间由于工作的原因,需要对TCP的序列号和确认号进行深入学习,下面便是我学习后的一些知识点总结,希望对TCP序列号和确认号感兴趣的朋友有一定帮助。

1.  序列号和确认号的简介及作用

TCP协议工作在OSI的传输层,是一种可靠的面向连接的数据流协议,TCP之所以可靠,是因为它保证了传送数据包的顺序。顺序是用一个序列号来保证的。响应包内也包括一个序列号,表示接收方准备好这个序列号的包。在TCP传送一个数据包时,它会把这个数据包放入重发队列中,同时启动计时器,如果收到了关于这个包的确认信息,便将此数据包从队列中删除,如果在计时器超时的时候仍然没有收到确认信息,则需要重新发送该数据包。另外,TCP通过数据分段中的序列号来保证所有传输的数据可以按照正常的顺序进行重组,从而保障数据传输的完整。

2.  TCP的通讯过程

在TCP通讯中主要有连接的建立、数据的传输、连接的关闭三个过程!每个过程完成不同的工作,而且序列号和确认号在每个过程中的变化都是不同的。

2.1 TCP建立连接

TCP建立连接,也就是我们常说的三次握手,它需要三步完成。在TCP的三次握手中,发送第一个SYN的一端执行的是主动打开。而接收这个SYN并发回下一个SYN的另一端执行的是被动打开。

这里以客户端向服务器发起连接来说明。

1)  第1步:客户端向服务器发送一个同步数据包请求建立连接,该数据包中,初始序列号(ISN)是客户端随机产生的一个值,确认号是0;

2)  第2步:服务器收到这个同步请求数据包后,会对客户端进行一个同步确认。这个数据包中,序列号(ISN)是服务器随机产生的一个值,确认号是客户端的初始序列号+1;

3)  第3步:客户端收到这个同步确认数据包后,再对服务器进行一个确认。该数据包中,序列号是上一个同步请求数据包中的确认号值,确认号是服务器的初始序列号+1。

注意:因为一个SYN将占用一个序号,所以要加1。

初始序列号(ISN)随时间而变化的,而且不同的操作系统也会有不同的实现方式,所以每个连接的初始序列号是不同的。TCP连接两端会在建立连接时,交互一些信息,如窗口大小、MSS等,以便为接着的数据传输做准备。

RFC793指出ISN可以看作是一个32bit的计数器,每4ms加1,这样选择序号的目的在于防止在网络中被延迟的分组在以后被重复传输,而导致某个连接的一端对它作错误的判断。

2.2 TCP传输数据

在TCP建立连接后,就可以开始传输数据了。TCP工作在全双工模式,它可以同时进行双向数据传输。这里为了简化,我们只谈服务器向客户端发送数据的情况,而客户端向服务器发送数据的原理和它是类似的,这里便不重复说明。
服务器向客户端发送一个数据包后,客户端收到这个数据包后,会向服务器发送一个确认数据包。

传输数据的简要过程如下:

1)  发送数据:服务器向客户端发送一个带有数据的数据包,该数据包中的序列号和确认号与建立连接第三步的数据包中的序列号和确认号相同;

2)  确认收到:客户端收到该数据包,向服务器发送一个确认数据包,该数据包中,序列号是为上一个数据包中的确认号值,而确认号为服务器发送的上一个数据包中的序列号+所该数据包中所带数据的大小。
数据分段中的序列号可以保证所有传输的数据按照正常的次序进行重组,而且通过确认保证数据传输的完整性。

2.3 TCP关闭连接

前面我们提到,建立一个连接需要3个步骤,但是关闭一个连接需要经过4个步骤。因为TCP连接是全双工的工作模式,所以每个方向上需要单独关闭。在TCP关闭连接时,首先关闭的一方(即发送第一个终止数据包的)将执行主动关闭,而另一方(收到这个终止数据包的)再执行被动关闭。

关闭连接的4个步骤如下:

1)  第1步:服务器完成它的数据发送任务后,会主动向客户端发送一个终止数据包,以关闭在这个方向上的TCP连接。该数据包中,序列号为客户端发送的上一个数据包中的确认号值,而确认号为服务器发送的上一个数据包中的序列号+该数据包所带的数据的大小;

2)  第2步:客户端收到服务器发送的终止数据包后,将对服务器发送确认信息,以关闭该方向上的TCP连接。这时的数据包中,序列号为第1步中的确认号值,而确认号为第1步的数据包中的序列号+1;

3)  第3步:同理,客户端完成它的数据发送任务后,就也会向服务器发送一个终止数据包,以关闭在这个方向上的TCP连接,该数据包中,序列号为服务器发送的上一个数据包中的确认号值,而确认号为客户端发送的上一个数据包中的序列号+该数据包所带数据的大小;

4)  第4步:服务器收到客户端发送的终止数据包后,将对客户端发送确认信息,以关闭该方向上的TCP连接。这时在数据包中,序列号为第3步中的确认号值,而确认号为第3步数据包中的序列号+1;

注意:因为FIN和SYN一样,也要占一个序号。理论上服务器在TCP连接关闭时发送的终止数据包中,只有终止位是置1,然后客户端进行确认。但是在实际的TCP实现中,在终止数据包中,确认位和终止位是同时置为1的,确认位置为1表示对最后一次传输的数据进行确认,终止位置为1表示关闭该方向的TCP连接。

3.  实际数据包分析

结合上面的理论,下面我们访问网页来捕获数据包,通过实际的数据包来验证序列号和确认号在TCP连接建立、传输数据以及关闭连接时的变化。

打开科来网络分析系统,首先为减少数据干扰,在过滤器中设置只捕获TCP协议的数据,然后开始捕获,同时,访问www.csna.cn,待页面下载完成后,停止捕获。

此次环境中,客户端为192.168.0.92,服务器为:222.77.187.23。

3.1 TCP建立连接

在捕获的数据包中,首先我们来查看建立连接的三次握手信息,并且观察数据包中序列号和确认号的变化。为了让大家看的更加明白,我在这里使用了“添加数据包注释”的功能。
我们先来查看建立连接的第一步,如图1所示。

(图1  建立连接第一步)

图1中,客户端向服务器发起一个同步请求数据包,请求连接服务器的80端口,客户端随机产生一个初始序列号(ISN)为2712239078,确认号为0。

注意:在实际情况中,我们访问网站首先进行的是域名解析,这里我们设置了过滤器所以没有捕获到DNS数据包。
接下来我们再看建立连接的第二步。如图2。

(图2  建立连接第二步)

图2中,服务器收到客户的同步请求数据包后,并向客户端发送一个同步确认数据。这个数据包中,服务器随机产生一个初始序列号(1288781508),同时,将客户端发送的初始序列号(ISN)加1(2712239078+1=2712239079)以作为确认号发回给客户段进行确认。
我们再来查看建立连接的第三步,如下图3。

(图3  建立连接第三步)

图3中,客户端收到这个同步确认数据包后,再次对服务器进行一次确认。在这个数据包中,序列号为上一个数据包的确认号(2712239079),确认号为服务器的初始序列号(ISN)加1(1288781508+1=1288781509),以对服务器的同步确认数据包进行确认,这样TCP连接就建立了。

3.2 TCP传输数据

TCP连接建立后,马上就开始传输数据,这里客户端主动向服务器发送一个GET请求,来提交自己的请求信息。
下面我们就来看客户端发送给服务器的GET请求数据包,如图4所示,

(图4  传输数据)

图4中的是客户端向服务器发送的GET请求据数据包,我们注意看序列号和确认号的值!该数据包中,序列号为2712239079,确认号为1288781509,这和三次握手的第三步的数据包中的序列号和确认号相同。
从图4中看出这个数据包的大小为1018字节,其中减去14字节Ethernet报头,20字节的IP报头,20字节的TCP报头和4字节的FCS(1018-14-20-20-4=960),得到传输的数据大小为1432。我们将该数据包中的序列号加上该数据大小(即2712239079+960=2712240039),发现与“下一个序列号”的值完全吻合,也就是下一个数据包中服务器发送给客户端的数据包中的确认号,如图5所示。

(图5 确认收到)

注意:“下一个序列号”是科来网络分析系统为了方便用户查找下一个连续数据包,而根据数据包序列号和确认号自动计算得出,该字段在实际数据包中是不存在的。

3.3 TCP关闭连接

在传输数据完成之后,TCP会关闭连接,这里是服务器主动关闭该方向上的TCP连接。我们继续来观察捕获的数据包,先来看关闭连接的第一步,这里是服务器主动发起关闭,如图6。

(图6  关闭连接第一步)

图6中,服务器向客户端主动发起确认位和终止位同时置为1的数据包,确认位置1表示对最后一次传输的数据进行确认,终止位置1表示关闭该方向的TCP连接,关闭服务器和客户端的TCP连接。在这个数据包中,序列号为客户端发送的上一个数据包中所带的确认号值(1288781777),而确认号为服务器发送的上一个数据包中的序列号+该数据包所带的数据的大小(2712238597+1432=2712240039);

然后客户端收到该终止数据包,会对服务器发送一个确认数据包,该数据包中,序列号为第1步中的确认号值(2712240039),而确认号为第1步的数据包中的序列号+1(1288781777+1=1288781778);
我们注意观察序列号和确认号的变化情况,如图7所示。

(图7  关闭连接第二步)

随后,就是来自客户端被动发起的关闭,它与服务器主动发起的关闭同理,只不过这次是被动关闭客户端方向上的TCP连接,我们就不重复说明,如图8和图9所示。

(图8  关闭连接第三步)

(图9  关闭连接第四步)

我们根据以上对TCP的建立连接、传输数据和关闭连接三个过程的抓包分析,成功的验证了前面所说的理论。


                                                                                                                         CSNA网络分析论坛
                                                                                                                                KelvinFu
                                                                                                                                2006-11-10

[ 本帖最后由 KelvinFu 于 2006-11-10 17:22 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?CSNA会员注册

×

评分

1

查看全部评分

回复

使用道具 举报

发表于 2006-11-10 17:26:55 | 显示全部楼层
英雄啊!!做成PDF文档好吗??我现在最需要这些了!!
回复

使用道具 举报

发表于 2006-11-10 17:28:12 | 显示全部楼层
看得太快了没看见前面的PDF下载连接,不好意思啊!
回复

使用道具 举报

发表于 2006-11-10 18:38:39 | 显示全部楼层
我也是照LZ样分析作的,却写不出文章,差距呀
回复

使用道具 举报

发表于 2006-11-10 23:04:30 | 显示全部楼层
好的知识!谢谢,收藏了。
回复

使用道具 举报

发表于 2006-11-11 09:33:01 | 显示全部楼层
3)  第3步:客户端收到这个同步确认数据包后,再对服务器进行一个确认。该数据包中,序列号是上一个同步请求数据包中的确认号值,确认号是服务器的初始序列号+1。


"序列号是上一个同步请求数据包中的确认号值",那这个序列号为0,我不理解这个结果的含义。
回复

使用道具 举报

发表于 2006-11-11 10:50:07 | 显示全部楼层
仔细看完,感觉十分好,正在理解。
回复

使用道具 举报

发表于 2006-11-11 13:24:10 | 显示全部楼层
佩服佩服!!
回复

使用道具 举报

 楼主| 发表于 2006-11-11 19:53:40 | 显示全部楼层
原帖由 xyzl6508066 于 2006-11-11 09:33 发表
3)  第3步:客户端收到这个同步确认数据包后,再对服务器进行一个确认。该数据包中,序列号是上一个同步请求数据包中的确认号值,确认号是服务器的初始序列号+1。


"序列号是上一个同步请求数据包中的确 ...


是的啊,是第二步同步确认数据包中的确认号值撒!而不是第一步中的同步数据包中的确认号值!
回复

使用道具 举报

发表于 2006-11-16 10:38:28 | 显示全部楼层
分析得精僻啊,学习学习。
回复

使用道具 举报

发表于 2006-11-16 13:08:01 | 显示全部楼层
努力学习中!
回复

使用道具 举报

发表于 2006-11-16 19:31:20 | 显示全部楼层
谢谢`~~~

一看就懂了; `~~~~

我的老师用 sniffer 也象你这样解说过`~~

不错1!!!   希望还有类试的教程~
回复

使用道具 举报

发表于 2006-11-17 21:13:06 | 显示全部楼层
好东西啊,好好学习
回复

使用道具 举报

发表于 2006-11-27 17:48:07 | 显示全部楼层
佩服的一塌糊涂!。。。。。。
回复

使用道具 举报

发表于 2006-11-27 21:27:55 | 显示全部楼层
想跟LZ请教一下顺序号是在数据到达目的地后重新组合的顺序号
那偏移量是什么呢?
他们之间有什么关系和区别吗?
谢谢先!
要是在沙坪坝可以请你吃饭的!
回复

使用道具 举报

 楼主| 发表于 2006-11-28 10:45:03 | 显示全部楼层
原帖由 san980 于 2006-11-27 21:27 发表
想跟LZ请教一下顺序号是在数据到达目的地后重新组合的顺序号
那偏移量是什么呢?
他们之间有什么关系和区别吗?
谢谢先!
要是在沙坪坝可以请你吃饭的!


老乡,你可以看看,这个关于偏移量的帖子
http://www.csna.cn/forum.php?mod=viewthread&tid=887
回复

使用道具 举报

发表于 2006-11-28 20:21:55 | 显示全部楼层
原帖由 KelvinFu 于 2006-11-28 10:45 发表


老乡,你可以看看,这个关于偏移量的帖子
http://www.csna.cn/forum.php?mod=viewthread&tid=887

多谢了哈!
回复

使用道具 举报

发表于 2006-11-29 21:35:51 | 显示全部楼层
终于仔细的看完了,也做了相关的试验,就是我不知道从什么地方可以看出是关闭的四步开始
还有点晕
看来差距不是一丁点也!
想问问楼主,这个序列号和确认号在实际应用中在什么地方要注意它们?
还有那四个字节的FCS是怎么来的啊!

刚开始学,请楼主见谅了!
回复

使用道具 举报

发表于 2006-12-21 07:43:09 | 显示全部楼层
什么什么可以到达此境界
回复

使用道具 举报

发表于 2007-1-7 23:41:25 | 显示全部楼层

回复 #1 KelvinFu 的帖子

老大好东西呀谢谢受教了
回复

使用道具 举报

发表于 2007-1-9 01:26:06 | 显示全部楼层
感觉有点问题.

编号10 为客户端(192.168.0.92)向服务器(222.77.187.23)发送GET请求
编号11 为服务器(222.77.187.23)确认客户端(192.168.0.92)的GET请求
编号12就应为服务器(222.77.187.23)向客户端(192.168.0.92)传输HTML文件(猜想)
编号13 为服务器主动关闭该方向上的TCP连接

编号12的确认还没收到,编号13就开始拆除连接了???
回复

使用道具 举报

 楼主| 发表于 2007-1-9 09:33:07 | 显示全部楼层
原帖由 wap12345 于 2007-1-9 01:26 发表
感觉有点问题.

编号10 为客户端(192.168.0.92)向服务器(222.77.187.23)发送GET请求
编号11 为服务器(222.77.187.23)确认客户端(192.168.0.92)的GET请求
编号12就应为服务器(222.77.187.23)向客户端(192.16 ...


您所描述的HTTP通讯过程是正确的!
8过我在文章的前面说了条件啊,因为TCP是全双工的协议,在双向上都会有数据传输,它们在双向上传输数据原理都一样的,所以我在这里只介绍了单边传输过程,也就是客户端向服务器发送GET请求数据的过程,至于服务器向客户端作出的HTTP响应,我在这里省略掉了!(编号12HTTP响应的数据包,也没有图中显示的)

[ 本帖最后由 KelvinFu 于 2007-1-9 09:37 编辑 ]
回复

使用道具 举报

发表于 2007-3-26 16:42:29 | 显示全部楼层
真是太好了,能学到好东西!!
回复

使用道具 举报

发表于 2007-3-27 13:15:39 | 显示全部楼层
说的太好了,学到好多啊。谢了。
回复

使用道具 举报

发表于 2007-3-30 13:24:35 | 显示全部楼层
写的太好了,学到了好多知识。谢了。
回复

使用道具 举报

发表于 2007-4-18 16:51:25 | 显示全部楼层
写得不错啊,谢谢楼主!
回复

使用道具 举报

发表于 2007-4-18 18:15:47 | 显示全部楼层
认真学习。。。^_^
回复

使用道具 举报

发表于 2007-4-21 16:35:56 | 显示全部楼层
下了PDF在慢慢看。。
回复

使用道具 举报

发表于 2007-4-24 10:48:18 | 显示全部楼层

好贴

回复

使用道具 举报

发表于 2007-5-5 22:12:56 | 显示全部楼层

回复 #1 KelvinFu 的帖子

好!好!好!............
辛苦了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | CSNA会员注册

本版积分规则

快速回复 返回顶部 返回列表