拥塞窗口cwnd的理解[通俗易懂]

拥塞窗口cwnd的理解[通俗易懂] 拥塞窗口cwnd的理解:  开始的时候拥塞窗口是1,发一个数据包等ACK回来 cwnd++即2,这个时候可以发送两个包,发送间隔几乎没有 对方回的ACK到达发送方几乎是同时到达的.一个RTT来回 cwnd就翻倍,cwnd++,cwnd++即4了.如此下去,cwnd是指数 增加.     snd_cwnd_

大家好,欢迎来到IT知识分享网。

 

拥塞窗口cwnd的理解:
 
 开始的时候拥塞窗口是1,发一个数据包等ACK回来
 cwnd++即2,这个时候可以发送两个包,发送间隔几乎没有
 对方回的ACK到达发送方几乎是同时到达的.一个RTT来回
 cwnd就翻倍,cwnd++,cwnd++即4了.如此下去,cwnd是指数
 增加.
 
 拥塞窗口cwnd的理解[通俗易懂]
 
拥塞窗口cwnd的理解[通俗易懂]
 
 snd_cwnd_clamp这个变量我们可以不管,假定是一个大值.
 窗口到了我们设置的门限,snd_cwnd不在增加
而通
 过snd_cwnd_cnt变量来计数增加,一直增加到
 大过cwnd值,cwnd才加1,然后snd_cwnd_cnt重新计数
 通过snd_cwnd_cnt延缓cwnd计数
 
 由于TCP是固定大小报文,每一个snd_cwnd代表了一个报文
 段的增加,snd_cwnd_cnt则看成byte的增加
 
void tcp_cong_avoid(struct send_queue* sq)
{

    /* In saft area, increase*/
    if (sq->snd_cwnd <= sq->snd_ssthresh){

        if (sq->snd_cwnd < sq->snd_cwnd_clamp)
            sq->snd_cwnd++;
    }
    else{ 
        /* In theory this is tp->snd_cwnd += 1 / tp->snd_cwnd */
        if (sq->snd_cwnd_cnt >= sq->snd_cwnd) {

            if (sq->snd_cwnd < sq->snd_cwnd_clamp)
                sq->snd_cwnd++;
            sq->snd_cwnd_cnt = 0;
        } else
            sq->snd_cwnd_cnt++;
    } 
}

 
snd_cwnd 还没到达门限不断增加snd_cwnd++
 
snd_cwnd++                      | <–snd_ssthresh
                                ^
 
到达了snd_ssthresh转入拥塞避免,这个阶段由变量snd_cwnd_cnt来控制
 
转入拥塞,由于snd_cwnd_cnt从0开始小于snd_ssthresh,即从snd_ssthresh那个点开始计数
一致计数达到snd_cwnd拥塞窗口的值,但是还小过牵制snd_cwnd_clamp值
                                     
                              snd_cwnd_clamp
                                     ^

        snd_cwnd++                   |            | <–snd_ssthresh
                                                  ^
                                        snd_cwnd++        
                                                              snd_cwnd_clamp
                                                                     ^
                                    snd_cwnd_cnt++                   |            | <–snd_ssthresh
                                                                                  ^
                                                   0      —>       snd_cwnd_cnt++
 
 
                   <——                       时间                      ——->

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/25209.html

(0)

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信