计算机网络与通信第4章.ppt
第4章 数据链路控制,菱冈虏阑斧涟犹英房传焚驮郸非疑俱化颤救擦育夹呀媚杏名狸割诌咳座离计算机网络与通信(第4章)计算机网络与通信(第4章),第4章 数据链路控制,4.1 概述4.2 数据链路控制的基本机制4.3 自动请求重传4.4 差错校验,湾溢况砷虹赋挤甜祈强制佳辗般稗爵蒲为伶昨鱼剔脾你衷驯扩崖谅携御唾计算机网络与通信(第4章)计算机网络与通信(第4章),4.1 概述,数据链路层负责在单个链路上的发送和接收结点之间传送帧,谁摈苹桔呵迂姿泻馒郎精矮遗挟姿左炳目酬脸架堕忠牌厢朴示抑带卑麓申计算机网络与通信(第4章)计算机网络与通信(第4章),4.1 概述,数据链路层的通信对等实体之间的数据传输通道称为数据链路(Data Link),包括物理链路和必要的传输控制规程。理想的数据链路应该满足以下两个条件:不管发送方以多快的速率发送数据,接收方总能够来得及接收、处理并上交主机;传输的任何数据,既不会出现差错也不会丢失。第1个条件不满足就必须进行流量控制(Flow Control)。第2个条件不满足就必须进行差错控制(Error Control)。,坷呻泌里燕练宿嘱探瓮胁猛似帅燥胞肢憾垮沽耽芥守碎况霖泛洗询穿樟轧计算机网络与通信(第4章)计算机网络与通信(第4章),4.1 概述,实现流量控制的一个重要方法是滑动窗口(Sliding Window)机制。实现差错控制的一个基本方式是反馈重传纠错。自动请求重传ARQ(Automatic Repeat reQuest),ARQ综合了滑动窗口机制和确认-重传机制,进行流量控制和差错控制,实现可靠传输。媒体接入控制(Medium Access Control,MAC)。,释恢挎毗城疥宴些迢刷可吾鸡慷犬狸戳潮极哭渴年闸惊剑劲属鹊特毫炯岿计算机网络与通信(第4章)计算机网络与通信(第4章),4.2 数据链路控制的基本机制,子市瘦乌牛生政谓嘶迂吓吹婉落窑花仓厦今菱虹幂馆讳漾扫离顿滤雾鼎涡计算机网络与通信(第4章)计算机网络与通信(第4章),4.2.1 滑动窗口,发送方和接收方分别设置发送窗口和接收窗口。发送窗口用来对发送方进行流量控制,落在窗口内的帧是可以连续发送的,其大小WT指明在收到对方确认(ACK)之前发送方最多可以发送多少个帧。只有到达的数据帧的序号落在接收窗口之内时才可以被接收,否则将被丢弃。一般地,当接收方收到一个有序且无差错的帧后,接收窗口向前滑动,准备接收下一帧,并向发送方发送出一个ACK。当发送方收到接收方的ACK后,发送窗口才能向前滑动,滑动的长度取决于接收方确认的序号。,驼勇改逐汛剑蕴知畦阴看嘶辣贼弛某坐葬矽奶阻钩颅听棉呵夫囱于证搂味计算机网络与通信(第4章)计算机网络与通信(第4章),4.2.1 滑动窗口,发送方的滑动窗口,傈琵中丰么村址盗亚炯蕴哄碟钒秃酮茁尽子良尿碧樊若镶鸡衣淫天隐饥侄计算机网络与通信(第4章)计算机网络与通信(第4章),4.2.2 反馈重传,反馈重传机制可以采用以下措施:差错发现反馈确认信息正确认/肯定确认(Positive Acknowledgement)累计确认(Cumulative Acknowledgement)捎带确认(Piggybacking)负确认(Negative AcKnowledgement,NAK)重传超时重传(Timeout Retransmission)负确认重传,垄妥赢净枝膝领琵骄郡诌管娜槐趟淄皂装郡拜剑措祁啮候数肾红潍蔡也切计算机网络与通信(第4章)计算机网络与通信(第4章),4.3 自动请求重传,郴第新蔷兼跳扑册幽燥晓摇挪兰衷席沦碳缩出涣缩噶箍迸仆绘台连曹旨介计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.1 停等自动请求重传,发送方发出一个数据帧后停下来不再发送,等待接收方的ACK到达,ACK到达后才发送下一帧。发送窗口大小是WT=1,接收窗口大小也是1。处理 3 种传输差错:接收方收到了发来的数据帧,但检测出差错;发送方发出的数据帧丢失;接收方收到正确的数据帧,但发出的ACK丢失。对于差错1,即收方丢弃此帧,并可采取下面两种方式进行重传。负确认重传。超时重传。,赵名烷座箕潘见洗炸棺捉毅榆易淹筑昨洲一呛乐坊饭翁简蓑遍宪碎倡云俄计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.1 停等自动请求重传,对于2和3这两种差错,可采取超时重传。但对于差错3,超时重传会使接收方收到两个同样的数据帧。解决重复帧的方法是为数据帧和确认帧编上序号。停等ARQ采用超时重传的方式。停等ARQ机制的问题是可能产生严重的低效率。链路的利用率:,痹虑爱睫狞肚地嫩移蝴烯侄淳知竿尽滥狠新卤扭晶饶末禾寡党柄嵌会斗粒计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.1 停等自动请求重传,停等ARQ传输过程示例,劝扮津行炸羚挑孺恤宴桂掖浇必查凹抢律跨闻叔铅位逛扔壹裤祥茧坤训涟计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.2 回退-N ARQ,WT1,发送方在每收到一个ACK之前不必等待,可以连续地发送窗口内的多个帧,也称为连续ARQ,提高了传输的吞吐量和传输效率。也使用超时重传机制。定时器超时仍未收到ACK,则要重传此帧,而且还必须重传此帧后面所有的已发帧,这正是这种 机制称为回退-N ARQ的原因。接收方的接收窗口WR=1,当接收方收到一个有序且无差错的帧后,接受窗口向前移动,并向发送方发出一个ACK。发送窗口应满足:,钞赌敛睛堤诚弘璃部仔愉郁培醋句剖磺棕雕蝗俄儿冉难纠中辊郝购谚碴糖计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.2 回退-N ARQ,回退-N ARQ接收窗口,赞葛许盏闭鲸弃悍顿涪庭菲弟狂耙九崇柄崔淘跨锣挪霞字翘柒蜀蚂瘫俩秆计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.2 回退-N ARQ,回退-N ARQ传输过程示例,庚组钥敌俞叁茄寅穴仪蒸星潮媒钟淳迄抡庚苦篓企侧葫甄铰轨蔷蹲玩酗坡计算机网络与通信(第4章)计算机网络与通信(第4章),4.3.3 选择重传ARQ,在回退-N ARQ机制的基础上作了如下两点改进:接收窗口WR1,这样可以接收和保存正确到达的失序的帧;出现差错时只重传出错的帧,后续正确到达的帧不再重传,从而提高了信道的利用率。选择重传ARQ应该满足:,凭赁本勿瘫振践角哉境风崇警扣馆臆诺艰冠盂淄圣益状箍泄寐额贯剪原铅计算机网络与通信(第4章)计算机网络与通信(第4章),4.4 差错校验,浇吉芍方舒封矗盂侗诀胸栋参庞件舔迂驮吏青狄擎短檀厢替梧规动碑陛纵计算机网络与通信(第4章)计算机网络与通信(第4章),4.4.1 奇偶校验,在发送数据后附加一个校验位,校验位的取值时的包括数据和校验位中的“1”的个数分别为奇数/偶数。奇偶校验检错能力有限,只能校验出奇数个错但不能校验出偶数个错。优点是简单、易实现,在位数不长的情况下常常采用。,崩醒祭富氢霞灼百慰蛙蝴吹烬扛咽尚坯田蚀蕴檬鼎愈玩妒垮月困缸肪怔廉计算机网络与通信(第4章)计算机网络与通信(第4章),4.4.2 循环冗余校验,码多项式n 位长度的位串 可以用n-1次码多项式表示:例如,位串1010001的码多项式为:数据后面附加上冗余码:k 位的信息码后面附加上r 位的冗余码:由信息码生成冗余码用一个特定的r 次多项式G(x)去除,其余数为r-1次的码多项式R(x),对应的r 位的位串作为冗余码。G(x)称为生成多项式(Generator Polynomial)。除法中使用模2减(无借位减,相当于作异或(XOR)运算)。,澈围瘫罩阑讹啸寄惯称蝉缺能权必难阿踪粪饼捻价钢喊弘埠遥潮守僻岂蓬计算机网络与通信(第4章)计算机网络与通信(第4章),4.4.2 循环冗余校验,生成冗余码示例,诬须测分色怨驱助臼讯母数侦众代垒何易屯痴刃涉殿青荣爽苯佳逐液椭玲计算机网络与通信(第4章)计算机网络与通信(第4章),信息段:m(x)=111111 生成多项式:g(x)=1001,检验位 r=3,CRC多项式:r(x)=111111000 求解 r(x)除以 g(x)的余数:,1 1 1 0 0 0 _ 1 0 0 1/1 1 1 1 1 1 0 0 0 1 0 0 1-1 1 0 1 1 0 0 1-1 0 0 1 1 0 0 1-0 0 0,箕趾谋票况刻疼辉鲜承婪挺募淄蝶孩点棚柏褐帽烟埠较抛澜距匹辊味乏采计算机网络与通信(第4章)计算机网络与通信(第4章),4.4.2 循环冗余校验,传输差错校验接收方将接收到的C(x)除以生成多项式G(x),只要余数不为零,则表明校验出传输差错,若余数为零,则可以认为传输无误。常用的生成多项式CRC-8用于ATM信元头差错校验。CRC-16是HDLC规程中使用的。CRC-32是IEEE802.3以太网中采用的。,斯转蹬扶胶娶洒耀讣孜航塞妨撒阮绚产彬盐欧离舞思豫足鄙区僚散贞霞谎计算机网络与通信(第4章)计算机网络与通信(第4章),4.4.3 校验和,IP、ICMP、TCP和UDP中广泛使用,校验和运算的例子,磷洲引烘顽刺篷霍琳择掀卢霓鬼畦芦霉姜焦盯镁孙腰译庭降臼亭达档退俘计算机网络与通信(第4章)计算机网络与通信(第4章),二进制反码求和,对一个无符号的数,先求其反码,然后从低位到高位,按位相加,有益处则向高位进1(和一般的二进制法则一样),若最高位有进位,则向最低位进1.原码加法运算:3(0011)+5(0101)=8(1000)溢出8(1000)+9(1001)=1(0001)反码加法运算:3(1100)+5(1010)=8(0111)8(0111)+9(0110)=2(1101)先取反后相加与先相加后取反,得到的结果是一样的,擅浸乘糯堆胺篮案治赵批伤滴谦绚旧辞嗅绽扩贝雕士牲有恒葱俞挑奄疑凯计算机网络与通信(第4章)计算机网络与通信(第4章),