TCP 序列号和确认号相关举例解释来啦

本文详细介绍了TCP连接中序列号和确认号的变化过程,包括三次握手和四次挥手阶段,以及数据传输阶段。通过万能公式解释了TCP报文的序列号和确认号如何计算,并结合实例加深理解。此外,还讨论了TCP头部的序列号、确认号和控制位的作用,以及它们如何解决网络包乱序和丢包问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在《我要证明网》上,我发现很多人对 TCP 序列号和确认号的变化都是懵懵懂懂的,只知道三次握手和四次挥手过程中,ACK 报文中确认号要 +1,然后数据传输中 TCP 序列号和确认号的变化就不知道了。

也有很多同学跟我反馈,希望我写一篇关于 TCP 序列号和确认号变化过程的文章。大家别小看这个基础知识点,其实很多人都不知道的。

所以,这次就跟大家聊聊以下过程中,TCP 序列号和确认号是如何变化的?

  • 三次握手中 TCP 序列号和确认号的变化
  • 数据传输中 TCP 序列号和确认号的变化
  • 四次挥手中 TCP 序列号和确认号的变化

万能公式

我根据经验总结了一条万能公式。

发送的 TCP 报文:

  • 公式一:序列号 = 上一次发送的序列号 + len(数据长度)。特殊情况,如果上一次发送的报文是 SYN 报文或者 FIN 报文,则改为 上一次发送的序列号 + 1。
  • 公式二:确认号 = 上一次收到的报文中的序列号 + len(数据长度)。特殊情况,如果收到的是 SYN 报文或者 FIN 报文,则改为上一次收到的报文中的序列号 + 1。

可能有点抽象,接下来举一些实际的场景,加深对这个万能公式的理解。

先给大家看看 TCP 序列号和确认号在 TCP 头部的哪个位置。可以看到,这两个字段都是 32 位。

在这里插入图片描述在这里插入图片描述

这里重点关注这三个字段的作用:

  • 序列号:在建立连接时由内核生成的随机数作为其初始值,通过 SYN 报文传给接收端主机,每发送一次数据,就「累加」一次该「数据字节数」的大小。用来解决网络包乱序问题。
  • 确认号:指下一次「期望」收到的数据的序列号,发送端收到接收方发来的 ACK 确认报文以后,就可以认为在这个序号以前的数据都已经被正常接收。用来解决丢包的问题。
  • 控制位:用来标识 TCP 报文是什么类型的报文,比如是 SYN 报文、数据报文、ACK 报文,FIN 报文等。

三次握手阶段的变化

先来说说三次握手中 TCP 序列号和确认号的变化。

假设客户端的初始化序列号为 client_isn,服务端的初始化序列号为 server_isn,

下面是一个简单的TCP报文的示例: ``` 0 4 8 12 16 20 24 28 +--------+--------+--------+--------+--------+--------+--------+--------+ | Source Port | Destination Port | +--------+--------+--------+--------+--------+--------+--------+--------+ | Sequence Number | +--------+--------+--------+--------+--------+--------+--------+--------+ | Acknowledgment Number | +--------+--------+--------+--------+--------+--------+--------+--------+ | HL | RSV | Control Bits | Window | +--------+--------+--------+--------+--------+--------+--------+--------+ | Checksum | Urgent Pointer | +--------+--------+--------+--------+--------+--------+--------+--------+ | Options | Padding | +--------+--------+--------+--------+--------+--------+--------+--------+ ``` 其中各字段的含义如下: - Source Port:源端口,指发送方的端口。 - Destination Port:目标端口,指接收方的端口。 - Sequence Number:序列号,用于标识TCP报文的顺序。 - Acknowledgment Number:确认,用于标识接收方已经收到的数据。 - HL:头部长度,指TCP头部的长度。 - RSV:保留位,暂时没有使用。 - Control Bits:控制位,用于标识TCP报文的类型,如SYN、ACK、FIN等。 - Window:窗口大小,指接收方缓冲区的大小。 - Checksum:校验,用于检测TCP报文的错误。 - Urgent Pointer:紧急指针,用于标识报文中的紧急数据。 - Options:选项,用于传输一些可选的数据,如MSS、SACK等。 - Padding:填充,用于将TCP头部的长度扩展到一个4字节的边界。 需要注意的是,TCP报文中还包含了数据部分,但在上述示例中没有显示出来,因为数据部分的长度是不固定的,而且可以为空。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值