拥塞控制原理

在实践中,丢包一般是当网络变得拥塞时由于路由器缓存溢出引起的。分组重传因此作为网络拥塞的征兆来对待,但是却无法处理导致网络拥塞的原因,因为有太多的源想以过高的速度发送数据。为了处理网络拥塞原因,需要一些机制以在面临网络拥塞时遏制发送方。

拥塞代价

1、时延大。(排队)

2、发送方在遇到大时延时所进行的不必要重传会引起路由器利用其链路带宽来转发不必要的分组副本。

3、发送方必须执行重传以补偿因为缓存溢出而丢弃的分组。

4、当一个分组沿一条路径被丢弃时,每个上游路由器用于转发该分组到丢弃该分组而使用的传输容量最终被浪费掉了。

拥塞控制方法

1、端到端拥塞控制方法。网络层没有为运输层拥塞控制提供显示支持。当网络中存在拥塞,端系统也必须通过对网络行为的观察(如分组丢失与时延)来推断。tcp必须通过端到端的方法解决拥塞控制,因为ip层不会向端系统提供有关网络拥塞的反馈信息。

2、网络辅助的拥塞控制。在网络辅助的拥塞控制中,网络层构件(即路由器)向发送方提供关于网络中拥塞状态的显示反馈信息,通常有两种方式。一是直接反馈信息可以有网络路由器发给发送方。二是路由器标记或更新从发送方流向接收方的分组中的某个字段来只是拥塞的产生。一旦受到一个标记的分组,接收方就会向发送方通知该网络拥塞指示。注意到后一种形式的通知至少要经过一个完整的往返时间。

TCP拥塞控制

TCP必须使用端到端拥塞控制而不是网络辅助的拥塞控制,因为IP层不向端系统提供显示的网络拥塞反馈。

TCP所采用的方法是让每一个发送方根据所感知到的网络拥塞程度来限制其能向连接发送流量的速率。如果一个TCP发送方感到从它到目的地之间的路径上没什么拥塞,则tcp发送方增加其发送速率;如果发送方感知沿着该路径有拥塞,则发送方就会降低其发送速率。

TCP如何限制向其连接发送流量的?

运行在发送方的tcp拥塞控制机制跟踪一个额外的变量,即拥塞窗口(congestion window),表示为cwnd,它对一个tcp发送方能向网络中发送流量的速率进行了限制。特别是,在一个发送方中未被确认的数据量不会超过cwnd和rwnd中的最小值。

TCP发送方是如何感知到在它与目的地之间的路径上出现了拥塞的?

TCP发送方的“丢包事件”定义为:要么出现超时,要么收到来自接收方的3个冗余ACK(总共4个确认)。当出现过度的拥塞时,在沿着这条路径上的一台(或多台)路由器的缓存会溢出,引起一个数据报(包含一个TCP报文段)被丢弃。丢弃的数据报接着会引起发送方的丢包事件(要么超时要么收到3个冗余ACK),发送方就认为在发送方到接收方的路径上出现了拥塞。

给定cwnd值以控制发送速率的机制,tcp发送方怎样确定它应当发送的速率?

如果众多tcp发送方总体上发送太快,他们会拥塞网络,导致拥塞奔溃。然而,如果tcp发送方过于谨慎,发送太慢,他们不能充分利用网络的带宽。那么tcp发送方如何确定它们的发送速率,既使得网络不会拥塞,与此同时又能充分利用所有可用的带宽?tcp使用下列指导性原则回答这些问题:

1、一个丢失的报文段表意味着拥塞,因此当丢失报文段时应当降低tcp发送方的速率。

2、一个确认报文段只是该网络正在向接收方交付发送方的报文段,因此,当对先前未确认把文段的确认到达时,能够增加发送方的速率。

3、带宽探测。给定ACK指示原道目的地路径无拥塞,而丢包事件指示路径拥塞,TCP调节传输速率的策略是增加其速率以响应到达的ACK,除非出现丢包事件,此时才减小传输速率。

TCP拥塞控制算法

tcp采用的拥塞控制算法包括3个主要部分①慢启动;⑵拥塞避免;⑶快速恢复。慢启动和拥塞避免是tcp的强制部分,两者的差异在于对收到的ack做出反应时增加cwnd长度的方式。快速恢复是推荐部分,对tcp发送方并非是必需的。

慢启动

在慢启动状态,cwnd的值以1个MSS(最大报文段长度Maximum Segment Size,MSS,是指在报文段里应用层数据的最大长度,而不是指包括tcp首部的tcp报文段的最大长度)开始并且每当传输的报文段首次被确认就增加一个MSS(总的cwnd每次变成原来的两倍,指数增长)。

何时结束这种指数增长呢?

首先,如果存在一个有超时指示的丢包时间,tcp发送方将cwnd设置为1,并重新开始慢启动过程。它还将第二个状态变量的值sshthresh(慢启动阈值)设置为cwnd/2,即当检测到拥塞时将sshthresh置为拥塞窗口值的一般。

当cwnd的值等于sshthresh时,结束慢启动并且tcp转移到拥塞避免模式。

如果检测到3个冗余的ACK,这是tcp执行一种快速重传并进入快速恢复状态。

拥塞避免

在拥塞避免模式下,通用的方法是对于tcp发送方无论何时到达一个新的确认,就将cwnd增加一个MSS(线性增长)。

何时结束这种线性增长呢?

当出现超时时,与慢启动的情况一样,cwnd的值被设置为一个MSS,当丢包事件出现时,sshthresh的值被更新为cwnd值的一半。

若是出现3个冗余ACK,tcp将sshthresh的值设置为cwnd的一半,被将cwnd设置成cwnd=sshthresh+3*MSS,接下来进入快速恢复状态。

快速恢复

对于引起tcp进入快速恢复状态的缺失报文段,对收到的每个冗余的ACK,cwnd的值增加一个MSS。最终,当对丢弃报文段的一个ACk到达时,TCP在降低cwnd后进入拥塞避免状态。

如果出现超时事件,快速恢复在执行如同在慢启动和拥塞避免中相同的动作后,迁移到慢启动状态。

本文主要参考《计算机自顶向下学习方法》一书,仅做读书笔记用。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容