大家好,欢迎来到IT知识分享网。
拥塞窗口cwnd的理解:
开始的时候拥塞窗口是1,发一个数据包等ACK回来
cwnd++即2,这个时候可以发送两个包,发送间隔几乎没有
对方回的ACK到达发送方几乎是同时到达的.一个RTT来回
cwnd就翻倍,cwnd++,cwnd++即4了.如此下去,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++;
}
}
{
/* 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