做网站的尺寸1920,网络营销与直播电商课程,html网站开发例子,小程序商城模板下载TCP的流量控制
利用滑动窗口实现流量控制 设A向B发送数据#xff0c;连接建立时候#xff0c;B告诉A自身的接收窗口大小#xff0c;A的发送窗口大小不能超过接收方B的窗口大小
流量控制#xff1a;发送方发送速率不要太快#xff0c;要让接收方来得及接收。窗口大小的单…TCP的流量控制
利用滑动窗口实现流量控制 设A向B发送数据连接建立时候B告诉A自身的接收窗口大小A的发送窗口大小不能超过接收方B的窗口大小
流量控制发送方发送速率不要太快要让接收方来得及接收。窗口大小的单位是字节。
窗口大小每次可以根据需求发送调整消息。
如果A向B发送了零窗口通知而之后向B发送窗口100大小的通知但消息丢失了B一直没有收到B如果一直等待下去就是死锁现象
因此TCP为每个链接设置了计时器当一方收到零窗口消息启动计时器然后计时器时间到期还没有收到更改窗口大小通知那么就发送零窗口探测报文段TCP规定在零窗口情况下也要接收零窗口探测字段紧急报文段和确认报文段对方收到后发送现在的窗口值如果依然是零那么重新设置计时器。
TCP发送时机的控制机制 TCP维持一个变量等于报文最大长度MSS,一旦接收到的数据达到MSS字节就发送一个TCP报文段出去。
第二种机制是由发送方的应用进程指明要求发送报文段即推送操作。
第三种机制是发送方一个计时器期限到了将当前已有的缓存数据放入报文段。
使用Nagle算法
发送应用进程要把发送的数据逐个发送给发送缓存然后发送数据的第一个字节然后把后续到达的字节存储到缓存起来当收到对第一个字节的确认时候发送缓存中所有数据组装成一个报文段发出同时对后续到达缓存的报文段缓存以后只有收到前一个报文段确认后再发送后一个报文段。
糊涂窗口综合症 TCP接收方的缓存已经满了应用进程每次取用一个字节接着发送方又传来一个字节然后接收方发送确认通知窗口依然为一个字节这样效率很低。
要解决可以让接收方等待一段时间使接收缓存可以容纳一个最长报文段或者有一半空闲空间这样就可以通知新的窗口大小。
拥塞;对资源的需求大于可用资源
流量控制点到店的通信量的控制。
拥塞控制;防止将过多数据注入网络使网络过载。
TCP拥塞的控制方法
算法有4种慢开始拥塞避免快重传和快恢复。
假设数据单方向传输接收方有足够大的缓存空间即发送窗口大小由网络拥塞程度决定。
(1)慢开始和拥塞避免 发送方维持一个叫做拥塞窗cwnd(congestion window)的变量拥塞窗口大小取决于网络拥塞程度.发送方控制自己的发送窗口与拥塞窗口相等。假设接收方接收窗口足够大那么只考虑拥塞窗口发送方控制拥塞窗口大小的原则是只要没有发生拥塞就扩大拥塞窗口以便发送更多数据。
慢开始算法
当建立连接后从小到大逐步扩大数据量即逐步增大拥塞窗口大小。
SMSS(sender maximum segment size)为发送方最大报文段。
RFC 6681规定先将初始拥塞窗口cwnd设置为不超过2到4个SMSS的数值具体规定如下
1SMSS2190个字节设置初始拥塞窗口为2*SMSS字节。
2若1095字节30SMSS
拥塞窗口还可以不断增加收到一个新的报文段确认后拥塞窗口最多增加一个SMSS数值。
拥塞窗口cwnd每次的增加量min(N,SMSS)
N是刚刚确认的报文段字节数。
下面设置拥塞窗口单位为报文段为了方便描述。 开始时候发送方设置cwnd为1发送第一个报文段接下来每收到对一个报文段的确认拥塞窗口就加一。
接收到对一个报文段的确认然后拥塞窗口大小为2然后发送方可以连续发送两个报文段接收冯收到后发回两个确认然后拥塞窗口大小设置为4。
可见从1到2到4...,可见拥塞窗口大小在慢开始阶段是指数型增长的。
慢开始的慢是指TCP刚开始发送时候只发送一个报文段你为了试探网络的拥塞情况然逐步增大拥塞窗口。
为了防止cwnd过大造成网络拥塞设置慢开始门限ssthresh;
cwnd
cwndssthresh使用拥塞避免算法
cwndssthresh既可以使用慢开始算法又可以使用拥塞避免算法。
拥塞避免算法是为了使拥塞窗口缓慢增大即每经过一个往返时间RTT发送方拥塞窗口加1个报文段这样拥塞窗口大小便相对增加缓慢。