TCP协议的seq、ack的计算与实际中tcp断开的优化
-
wireshark显示的seq是相对序号
-
seq与ack都为4个字节
-
当连接建立后,每个包都必须把ACK置为1,并携带ack
-
seq的语义
- 序号范围[0,2^32-1],序号增加到 2^32-1 后,下个序号又回到 0。tcp是面向字节流的,每个字节流都会被按顺序编号,seq指的是当前包的第一个字节在整个数据流中应该在的位置
- 对于没有数据的传输,比如ACK,他在传输的整个数据流中是不占位置的,所以下一次实际有数据的seq还是这一次的seq
- SYN/FIN虽然没有业务数据的传输,但还是会让下一次的seq+1,ACK就不会
-
ack的语义,假如ack=n
- 我已收到前n-1个字节(包括第n-1),期望收到对方下个数据包的第一个字节的序号为n,其中特殊的是SYN/FIN都算1。
实际生活中tcp四次挥手的优化
课本上学到的四次挥手是这样的
a-fin->b
b-ack->a
b-fin->a
a-ack->b
但是在实际生活中,当一方关闭连接,另外一方没有数据发送时,马上关闭连接,也就将第二步的ack与第三步的fin合并为一步了,b会给a发送一个将fin和ack都标志为1的包,也就是
a-fin->b
b-ac