数据链路层的流量控制与可靠传输机制

流量控制 、可靠传输与滑动窗口机制

流量控制涉及对链路上的帧的发送速率的控制 ,以使接收方有足够的缓冲空间来接收每一个帧。例如,在面向帧的自动重传请求系统中 ,当待确认帧的数量增加时 ,有可能超出缓冲存储空间而造成过载 。流量控制的基本方法是由接收方控制发送方发送数据的速率 ,常见的方式有两种 : 停止-等待协议和滑动窗口协议 。

    停止-等待流量控制基本原理

发送方每发送一帧 ,都要等待接收方的应答信号 ,之后才能发送下一帧;接收方每接收一帧 , 都要反馈一个应答信号 ,表示可接收下一帧,如果接收方不反馈应答信号,则发送方必须一直等待。每次只允许发送一帧 ,然后就陷入等待接收方确认信息的过程中 ,因而传输效率很低 。

    滑动窗口流量控制基本原理

在任意时刻 ,发送方都维持一组连续的允许发送的帧的序号,称为发送窗口;同时接收方也维持一组连续的允许接收帧的序号 ,称为接收窗口。发送窗口用来对发送方进行流量控制,而发送窗口的大小 WT代表在还没有收到对方确认信息的情况下发送方最多还可以发送多少个数据帧。同理,在接收端设置接收窗口是为了控制可以接收哪些数据帧而不可以接收哪些帧 。在接收方只有当收到的数据帧的序号落入接收窗口内才允许将该数据帧收下 。若接收到的数据帧落在接收窗口之外 ,则一律将其丢弃。

下图给出了发送窗口和接收窗口的工作原理。

发送窗口控制发送端的发送速率


WR=1 的接收窗口的意义

在发送端,每收到一个确认帧,发送窗口就向前滑动一个帧的位置,当发送窗口内没有可以发送的帧 (即窗口内的帧全部是己发送但未收到确认的帧) ,发送方就会停止发送 ,直到收到接收方发送的确认帧使窗口移动 ,窗口内有可以发送的帧,之后才开始继续发送 。

在接收端 ,当收到数据帧后 ,将窗口向前移一个位置,并发回确认帧 ,若收到的数据帧落在接收窗口之外则一律丢弃 。

滑动窗口有以下重要特性 :

1)  只有接收窗口向前滑动时(同时接收方发送了确认帧),发送窗口才有可能(只有发送方收到确认帧才是一定)向前滑动。

2)从滑动窗口的概念看 ,停止-等待协议、后退 N 帧协议和选择重传协议只在发送窗口大小和接收窗口大小上有所差别 :

停止等待协议 :发送窗口大小 =1,接收窗口大小=1 ; 后退 N 帧协议:发送窗口大小>1 ,接收窗口大小=1; 选择重传协议 :发送窗口大小>1,接收窗口大小>1。

3) 当接收窗口的大小为 1 时,可保证帧的有序接收 。

4) 数据链路层的滑动窗口协议中 ,窗口的大小在传输过程中是固定的(注意与传输层的滑动窗口协议的区别)。

    可靠传输机制

数据链路层的可靠传输通常使用确认和超时重传两种机制来完成 。确认是一种无数据的控制帧,这种控制帧使得接收方可以让发送方知道哪些内容被正确接收。有些情况下为了提高传输效率,将确认捎带在一个回复帧中,称为捎带确认 。超时重传是指发送方在发送某一个数据帧以后就开启一个计时器 ,在一定时间内如果没有得到发送的数据帧的确认帧  ,那么就重新发送该数据帧,直到发送成功为止 。

自动重传请求 (Auto Repeat Request, ARQ ) ,通过接收方请求发送方重传出错的数据帧来恢复出错的帧 ,是通信中用于处理信道所带来差错的方法之一  。传统自动重传请求分为三种,即停-等式 ( Stop-and-Wait) ARQ、后退 N 帧 ( Go-Back-N)  ARQ 以及选择性重传(Selective Repate) ARQ  。后两种协议是滑动窗口技术与请求重发技术的结合 ,由于窗口尺寸开到足够大时,帧在线路上可以连续地流动 ,因此又称其为连续 ARQ协议。注意,在数据链路层中流量控制机制和可靠传输机制是交织在一起的 。

单帧滑动窗口与停止-等待协议

在停止-等待协议中 ,源站发送单个帧后必须等待确认 ,在目的站的回答到达源站之前 ,源站不能发送其他的数据帧 。从滑动窗口机制的角度看 ,停止-等待协议相当于发送窗口和接收窗口大小均为 1 的滑动窗口协议。

在停止-等待协议中 ,除了数据帧丢失 ,还可能出现以下两种差错 : 到达目的站的帧可能己遭破坏 ,接收站利用差错检测技术检出后,简单地将该帧丢弃。为了对付这种可能发生的情况,源站装备了计时器 。在一个帧发送之后 ,源站等待确认,如果在计时器计满时仍未收到确认 ,则再次发送相同的帧 。如此重复 ,直到该数据帧无错误地到达为止 。

另一种可能的差错是数据帧正确而确认帧被破坏  ,此时接收方已经收到了正确的数据帧,但发送方收不到确认帧 ,因此发送方会重传已经被接收的数据帧  ,接收方收到同样的数据帧时会丢弃该帧,并重传一个该帧对应的确认帧 。发送的帧交替地用0和1来标识 ,肯定确认则分别用 ACK0和 ACK1 来表示 ,当收到的确认有误时 ,则重传己发送的帧。

对于停止-等待协议,由于每发送一个数据帧就停止并等待 ,因此用 1bit 来编号就够 。在停止-等待协议中 ,若连续出现相同发送序号的数据帧 ,表明发送端进行了超时重传。连续出现相同序号的确认帧 ,表明接收端收到了重复帧 。

此外,为了超时重发和判定重复帧的需要,发送方和接收方都须设置一个帧缓冲区。发送端在发送完数据帧时 ,必须在其发送缓存中保留此数据帧的副本 ,这样才能在出差错时进行重传 。 只有在收到对方发来的确认帧 ACK 时,方可清除此副本 。

由下图可知,停止-等待协议通信信道的利用率很低 。为了克服这一缺点 ,就产生了另外两种协议 ,即后退 N帧协议和选择重传协议 。

停止-等待协议中数据帧和确认帧的发送时间关系

多帧滑动窗口与后退 N 帧协议 ( GBN )

在后退 N 帧式 ARQ 中,发送方不需要在收到上一个帧的 ACK 后才能开始发送下一帧 ,而是可以连续发送帧  。当接收方检测出失序的信息帧后,要求发送方重发最后一个正确接收的信息帧之后的所有未被确认的帧;或者当发送方发送了 N个帧后 ,若发现该 N个帧的前一个帧在计时器超时后仍未返回其确认信息 ,则该帧被判为出错或丢失 ,此时发送方就不得不又重传该出错帧及随后的 N个帧 。换句话说 ,接收方只允许按顺序接收帧 。

如图所示,源站向目的站发送数据帧 。当源站发完 0 号帧后,可以继续发送后续的 1 号帧、2 号帧等。源站每发送完一帧就要为该帧设置超时计时器 。由于连续发送了许多帧,所以确认帧必须要指明是对哪一帧进行确认 。为了减少开销 ,GBN协议还规定接收端不一定每收到一个正确的数据帧就必须立即发回一个确认帧 ,而是可以在连续收到好几个正确的数据帧后,才对最后一个数据帧发确认信息 ,或者可以在当自己有数据要发送时才将对以前正确收到的帧加以捎带确认 。这就是说 ,对某一数据帧的确认就表明该数据帧和这以前所有的数据帧均己正确无误地收到了。在图中,ACKn 表示对第 n 号帧的确认 ,表示接收方己正确收到了第 n 号帧及以前的所有帧,下一次期望收到第 n+1 号帧 (也可能是第 0 号帧)。接收端只按序接收数据帧 。 虽然在有差错的 2 号帧之后接着又收到了正确的 6 个数据帧,但接收端都必须将这些帧丢弃。接收端虽然丢弃了这些不按序的无差错帧 ,但应重复发送己经发送过的最后一个确认帧 ACK1  ( 这是防止己经发送过的确认帧 ACK1 丢失)。

后退 N帧协议的接收窗口为1,可以保证按序接收数据帧。若采用n个比特对帧编号 ,则其发送窗口的尺寸 WT 应满足:1 <= WT  <= 2^n - 1。若发送窗口的尺寸大于2^n - 1,则会造成接收方无法分辨新帧和旧帧。

从图中不难看出 ,后退 N 帧协议一方面因连续发送数据帧而提高了信道的利用率 ,但另一方面,在重传时又必须把原来己传送正确的数据帧进行重传 (仅因这些数据帧的前面有一个数据帧出了错) ,这种做法又使传送效率降低。由此可见,若信道的传输质量很差导致误码率较大时,后退 N帧协议不一定优于停止-等待协议。

GBN 协议的工作原理 :对出错数据帧的处理

多帧滑动窗口与选择重传协议(SR)

为进一步提高信道的利用率 ,可设法只重传出现差错的数据帧或者是计时器超时的数据帧。

但此时必须加大接收窗口,以便先收下发送序号不连续但仍处在接收窗口中的那些数据帧 。等到所缺序号的数据帧收到后再一并送交主机 。这就是选择重传 ARQ 协议。

在选择重传协议中 ,每一个发送缓冲区对应一个计时器 ,当计时器超时时,缓冲区的帧就会重传 。另外,该协议使用了比上述其他协议更有效的差错处理策略 ,即一旦接收方怀疑帧出错,就会发一个否定帧 NAK 给发送方 ,要求发送方对 NAK 中指定的帧进行重传 。如图所示。

选择重传协议

选择重传协议的接收窗口尺寸 WR 和发送窗口尺寸 WT 都大于 1,一次可以发送或接收多个帧。若采用n比特对帧编号,为了保证接收方向前移动窗口后 ,新窗口序号与旧窗口序号没有重叠部分,需要满足条件:接收窗口 WR+发送窗口 WT  <= 2^n。假定仍然采用累计确认的方法 ,并且接收窗口 WR 显然不应超过发送窗口 WT ( 否则无意义),那么接收窗口尺寸不应超过序号范围的一半:WR <= 2^(n - 1)。当接收窗口为最大值时 ,WTmax=WRmax=2^(n - 1)。需要提醒读者的是 ,一般情况下,在 SR 协议里面 ,接收窗口的大小和发送窗口的大小是相同的。

选择重传协议可以避免重复传送那些本己正确到达接收端的数据帧 ,但在接收端要设置具有相当容量的缓冲区来暂存那些未按序正确收到的帧 。接收端不能接收窗口下界以下或窗口上界以上的序号的帧 ,因此所需缓冲区的数目等于窗口的大小 ,而不是序号数目 。

补充问题

在停止-等待协议中 ,确认帧为什么不需要序号(如用 ACK0 和 ACK1 ) ?

为什么当用n个比特进行编号时 ,若接收窗口的大小为 1,则只有在发送窗口的大小 WT <= 2^n-1 时,连续ARQ 协议才能正确运行 ?

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

推荐阅读更多精彩内容