为什么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 自身具备重传机制。

相关推荐
init_23611 小时前
【HCIP-18】RSTP
网络
云计算练习生1 小时前
渗透测试行业术语扫盲(第一篇)—— 基础网络与协议类术语
网络·网络协议·安全·网络安全·渗透测试·渗透测试术语
张3蜂2 小时前
文件上传漏洞:数字世界的“特洛伊木马”
网络·安全
普普通通的南瓜2 小时前
无需域名,直通安全:一年期免费IP SSL证书
网络·网络协议·tcp/ip·安全·ssl
月亮!2 小时前
移动端测试重磅升级:跨平台自动化测试框架深度对比
运维·网络·人工智能·测试工具·容器·自动化·测试用例
阿部多瑞 ABU3 小时前
国内外大模型安全红队实测:角色越狱与分步诱导双路径可稳定绕过政治与技术防护
网络·安全·ai
青果全球http3 小时前
HTTP代理原理揭秘:如何实现高效数据中转?
网络·网络协议·http
im_AMBER3 小时前
weather-app开发手记 01 HTTP请求基础 | Axios GET 请求
笔记·网络协议·学习·计算机网络·http·axios
渡我白衣4 小时前
计算机组成原理(1):计算机发展历程
java·运维·开发语言·网络·c++·笔记·硬件架构