tcp - 了解 TCP 慢启动
问题描述
我试图了解 tcp 拥塞控制并遇到所谓的慢启动阶段,tcp 从仅发送 1 个 MSS 开始,然后在收到 ack 后继续向拥塞窗口添加 1 个 MSS。这一点很清楚。但在此之后,我提到的几乎所有书籍/文章都说这会导致每个 RTT 的 cwnd 加倍,显示如下我感到困惑的图像。
第一个段是明确的,tcp 发送它并在 RTT 之后接收 ack,然后将 cwnd 加倍,现在是 2。现在它传输两个段,第一个 ack 来自 RTT 使 cwnd 3 之后。但是第二段是在这使 cwnd 4 之后(即加倍)。所以我无法理解 cwnd 如何使每个 RTT 加倍,因为根据我的理解,在此示例中,cwnd 在第一个 RTT 上加倍,在第二个 RTT 上加倍,在其他时间再次加倍(RTT+tx我相信第一段的时间)。这种理解是否正确。请解释。
解决方案
在发送方收到两个段的 ack 后,CWND 增加 2,而不是 1。请注意,第 2 轮中的第二个 ack 在第 2 轮中的第一个 ack 之后到达,这就是为什么它们被认为是同一轮并花费 1 RTT。
推荐阅读
- html - 抓取文件中的持久非 utf-8 字符
- javascript - .on('scroll') 在使用 replaceWith() 方法后停止触发
- c++ - C++ - 时间执行 0 与 Chrono 库
- swift - 时间和日期格式化程序 SwiftUI JSON 数据
- angular - 将 [(ngModel)] 绑定到未定义的值
- azure - 如何在 Azure 函数中配置 MS.Extensions.Logging 日志级别?
- regex - 通过正则表达式在加载页面上的 DOM 中分离部分脚本标记
- java - 处理死信队列的配置
- php - 重新加载后cookie被销毁
- perl - Perl:寻找更快的搜索(通过文件)