TCP的流量控制和拥塞控制

TCP的流量控制和拥塞控制


流量控制
其实就是让发送方慢点,要让接收方来得及接收。利用滑动窗口实现。

具体实现
在通讯过程中,接收方根据自己接收缓存的大小,动态地调整发送方的发送窗口大小,即接收窗口rwnd(接收方设置确认报文段的窗口字段来讲rwnd通知给发送方),发送方的发送窗口取接收窗口rwnd和拥塞窗口的cwnd最小值。
发送窗口大小可以动态变化
TCP的流量控制和拥塞控制_第1张图片如果rwnd=0后,怎么打破这个局面呢?
TCP为每一个连接设有一个持续计时器,只要TCP连接的一方收到对方的零窗口通知,就启动持续计时器。 若持续计时器设置的时间到期,就发送一个零窗口探测报文段。接收方收到探测报文段时给出现在的窗口值。 若窗口仍然是0,那么发送方就重新设置持续计时器。

现在说下拥塞控制
出现拥塞的条件:对资源需求的总和>可用资源
网络中有许多资源同时呈现供应不足》网络性能变坏》吞吐量随着输入负荷增大而下降;拥塞控制就是为了全局性的防止过多资源注入到网络中。
拥塞控制四种算法
1.接收窗口:接收方根据接收缓存设置的值,并告知给发送方,反映接收方容量
2.拥塞窗口:发送方根据自己估算的网络拥塞程度而设置的窗口值,反映当前网络容量
慢开始和拥塞避免是一组的
慢开始相当于对网络的探测,所以呈指数型增长,之后拥塞避免再“加法增长”,ssthresh代表的是慢开始门限,而新的ssthresh则是将之前的网络拥塞最大值除于2。
TCP的流量控制和拥塞控制_第2张图片快重传和快恢复是一组的
快重传算法其实就是对冗余ack的处理,重复收到3次确认,则执行快重传算法,快恢复则是不需要将拥塞窗口降为1,而是降到新的ssthresh值就行。
TCP的流量控制和拥塞控制_第3张图片本文参考王道计算机网络视频写出,相当于自己的学习笔记。

你可能感兴趣的:(tcp)