为什么要TCP流量控制?
TCP流量控制不是为了减少网络压力,那是TCP拥塞控制的作用。
下面简单介绍一下TCP流量控制的目的:
作用对象:相互连接着的两个终端(发送端与接收端)。
解决问题:解决发送端与接收方吞吐量不匹配的问题,比如当一个发送端A每秒发10个数据包,而接收端B每秒只能接受1个数据包,那么就会出现丢包的情况,所以发送端与接收端要的吞吐量要匹配。
目的:让发送端根据接收端的接收能力动态的调整发送速率
如何进行TCP流量控制?
首先介绍TCP流量控制需要的几个变量:
- LastByteSent :最后发送的数据包的序号,由发送端进行维护
- LastByteAck:最后收到的ACK包确认的数据包序号,由发送端进行维护
- rwnd:接收窗口,由发送方进行维护,表示接收方还有多少空余空间,由接收方发回(与ACK一起?待查)。接收方将其rwnd值放入它发送给发送方的报文段的接收窗口字段中,通知发送方它在该连接的缓存中还有多少可用空间。
- LastByteRead:由接收方维护,表示应用程序最后从缓存里面读取的数据包的序号
- RcvBuffer:接收方缓存的最大值
- LastByteRcvd:从网络中到达的最后一个放入接收缓存的数据包的序号
如果要:要保证不因为溢出而丢包,即保证接收方缓存足以接收即将收到的数据。
即:LastByteRcvd−LastByteRead≤RcvBuffer
LastByteRcvd−LastByteRead≤RcvBuffer
又:rwnd=RcvBuffer−[LastByteRcvd−LastByteRead]
rwnd=RcvBuffer−[LastByteRcvd−LastByteRead]
联立可得,要达成TCP流量控制,满足下式:将未确认的数据量控制在值rwnd内:LastByteSent−LastByteAck≤rwnd
LastByteSent−LastByteAck≤rwnd
具体是如何进行的?
最简单的思路:rwnd=0时咱们不发送了,但这样会存在一个问题,就是如果之后没有ACK,那么连接就相当于断开了。
所以真正的解决方案是:当rwnd=0时,发送端发送只有一个字节的数据的报文段。这些报文段将会被接收方确认。最终缓存开始清空,并且确认报文里将包含一个非0的rwnd值
如何恢复?
等下一次ACK到来可能rwnd就变大了,到时候就可以发送更多的数据了。
UDP不提供流量控制。