为什么TCP设计中要设计ACK不重传?

问:

我们在讨论TCP握手挥手的时候,经常谈到报文丢失问题,如果ACK不重新发,就会间接导致SYN/FIN重新发送,岂不是会导致资源浪费?

答:

在 TCP 协议中,ACK(确认报文)本身不会重传。这是因为 ACK 是一种被动确认机制,不携带数据,也不需要可靠传输保证。若 ACK 丢失,对方无法收到确认,将触发超时重传机制,从而间接促使新的 ACK 被再次发送。

然而,在 TCP 三次握手或四次挥手阶段,如果 ACK 丢失,会导致对方的 SYN 或 FIN 报文被重传。例如:

  • 在握手过程中,若客户端发送的第三次 ACK 丢失,服务端会重发 SYN+ACK;客户端收到后再次发送 ACK。

  • 在挥手过程中,若最后一次 ACK 丢失,另一方会重发 FIN;收到后对方再发一次 ACK。

这种行为确实会带来一定的资源浪费,但代价很小。TCP 设计者认为:

  1. ACK 报文短小且丢包率极低;

  2. SYN/FIN 的重传机制已经能保证可靠性;

  3. 为 ACK 设计重传逻辑会增加协议复杂度。

因此,TCP 在可靠性和复杂度之间做了权衡:宁可允许少量控制报文重发,也不让 ACK 自身具备重传机制。

相关推荐
橘子真甜~5 小时前
C/C++ Linux网络编程15 - 网络层IP协议
linux·网络·c++·网络协议·tcp/ip·计算机网络·网络层
云老大TG:@yunlaoda3606 小时前
华为云国际站代理商IMS主要有什么作用呢?
tcp/ip·华为云·云计算·负载均衡
Allen正心正念20256 小时前
网络编程与通讯协议综合解析
网络
bing_feilong6 小时前
ubuntu中的WIFI与自身热点切换
网络
CodeByV6 小时前
【网络】UDP 协议深度解析:从五元组标识到缓冲区
网络·网络协议·udp
车载测试工程师7 小时前
CAPL学习-AVB交互层-概述
网络协议·tcp/ip·以太网·capl·canoe
虹科网络安全7 小时前
艾体宝洞察 | 利用“隐形字符”的钓鱼邮件:传统防御为何失效,AI安全意识培训如何补上最后一道防线
运维·网络·安全
石像鬼₧魂石8 小时前
Kali Linux 网络端口深度扫描
linux·运维·网络
鲸鱼电台分台9 小时前
工业应用通信协议:IEC104
网络协议
适应规律9 小时前
UNeXt-Stripe网络架构解释
网络