【发布时间】:2018-09-18 05:03:14
【问题描述】:
我试图了解 tcp 拥塞控制并遇到了所谓的慢启动阶段,tcp 从仅发送 1 个 MSS 开始,然后在收到 ack 后继续向拥塞窗口添加 1 个 MSS。这一点很清楚。但在此之后,我引用的几乎所有书籍/文章都说这会导致每个 RTT 的 cwnd 翻倍,显示如下我感到困惑的图像。
第一个段是明确的,tcp 发送它并在 RTT 之后接收 ack,然后将 cwnd 加倍,现在是 2。现在它传输两个段,第一个的 ack 在 RTT 使 cwnd 3 之后出现。但是第二段的 ack 在这使 cwnd 4 之后出现(即加倍)。所以我无法理解 cwnd 如何使每个 RTT 加倍,因为根据我的理解,在此示例中,cwnd 在第一个 RTT 上加倍,在第二个 RTT 上加倍,在其他时间再次加倍(RTT+tx我相信第一段的时间)。这种理解是否正确。请解释一下。
【问题讨论】:
-
当 cwnd 为(比如说)2 时,如果不存在拥塞,两个 ACK(或两个段一个)会快速连续到达(而不是在 2 * RTT 之后)。换句话说,在发送下一组段之前。这就是该算法有效地将 cws 翻倍的原因。
标签: tcp