计算机网络-5
3.1 数据链路层功能概述
数据链路层的研究思想
数据链路层基本概念
结点:
主机、路由器。
链路:
网络中两个结点之间的物理通道,链路的传输介质主要有双绞线、光纤和微波。分为有线链路、无线链路。
数据链路:
网络中两个结点之间的逻辑通道,把实现控制数据传输协议的硬件和软件加到链路上就构成数据链路。
帧:
链路层的协议数据单元,封装网络层数据报。
数据链路层负责通过一条链路从一个结点向另一个物理链路直接相连的相邻结点传送数据报。
数据链路层功能概述
数据链路层在物理层提供服务的基础上向网络层提供服务,其最基本的服务是将源自网络层来的数据可靠地传输到相邻节点的目标机网络层。其主要作用是加强物理层传输原始比特流的功能,将物理层提供的可能岀错的物理连接改造成为逻辑上无差错的数据链路,使之对网络层表现为一条无差错的链路。
功能一:为网络层提供服务
无确认无连接服务,有确认无连接服务,有确认面向连接服务。
有连接一定有确认!
功能二:链路管理
即连接的建立、维持、释放(用于面向连接的服务)。
功能三:组帧
功能四:流量控制
限制发送方
功能五:差错控制(帧错/位错)。
3.2 封装成帧和透明传输
封装成帧
封装成帧就是在一段数据的前后部分添加首部和尾部,这样就构成了一个帧。接收端在收到物理层上交的比特流后,就能根据首部和尾部的标记,从收到的比特流中识别帧的开始和结束。
首部和尾部包含许多的控制信息,他们的一个重要作用:帧定界(确定帧的界限)。
帧同步:接收方应当能从接收到的二进制比特流中区分出帧的起始和中止。
组帧的四种方法:
- 字符统计法
- 字符(节)填充法
- 零比特填充法
- 违规编码法
数据部分的极限值叫做:最大传送单元MTU。不同的协议MTU长度也不同
透明传输
透明传输是指不管所传数据是什么样的比特组合,都应当能够在链路上传送。因此,链路层就“看不见”有什么妨碍数据传输的东西。
当所传数据中的比特组合恰巧与某一个控制信息完全一样时,就必须采取适当的措施,使收方不会将这样的数据误认为是某种控制信息。这样才能保证数据链路层的传输是透明的。
透明传输在组帧上的应用
1.字符计数法
帧首部使用一个计数字段(第一个字节,八位)来标明帧内字符数。
痛点:鸡蛋放在一个篮子里了,当前一个计数字段发生错误,后面的所有帧都会发生错误。
2.字符填充法
字符填充法的过程:
3.零比特填充法
5110:遇到5个1 填充一个0(即使后面是0也要填充);发现5个1 删除一个0
4.违规编码法
由于字节计数法中 Count字段的脆弱性(其值若有差错将导致灾难性后果)及字符填充实现上的复杂性和不兼容性,目前较普遍使用的帧同步法是比特填充和违规编码法。
3.3.1 差错控制(检错编码)
差错从何来?
概括来说,传输中的差错都是由于噪声引起的。
全局性:1.由于线路本身电气特性所产生的随机噪声(热噪声),是信道固有的,随机存在的。
解决办法:提高信噪比来减少或避免干扰。(对传感器下手)
局部性:2.外界特定的短暂原因所造成的冲击噪声,是产生差错的主要原因。
解决办法:通常利用编码技术来解决。
数据链路层的差错控制
在数据链路层进行差错控制可以提早的发现差错,避免错误的数据一直传输下去
冗余编码
在数据发送之前,先按某种关系附加上一定的冗余位,构成一个符合某一规则的码字后再发送。当要发送的有效数据变化时,相应的冗余位也随之变化,使码字遵从不变的规则。接收端根据收到码字是否仍符合原规则,从而判断是否出错。
海明码不但可以知道出错了,还可以知道哪里出了错
编码VS编码
数据链路层编码和物理层的数据编码与调制不同。物理层编码针对的是单个比特,解决传输过程中比特的同步等问题,如曼彻斯特编码。而数据链路层的编码针对的是一组比特,它通过冗余码的技术实现一组二进制比特串在传输过程是否出现了差错。
检错编码–奇偶校验码
一个奇偶校验码例题
因为采用奇校验所以在原信息元前+1,1个数为5,选项中ABC 1个数为4,1个数发生了变化,D 1个数为5.1个数未发生变化,说明ABC发生了错误,而D不确定是否发生错误。因为发生偶数个出错无法检查出来。
奇偶校验码特点:只能检査出奇数个比特错误,检错能力为50%。
检错编码–CRC循环冗余码
简单方法看CRC循环冗余码
一个CRC循环冗余码例题
在数据链路层仅仅使用循环冗余检验CRC差错检测技术,只能做到对帧的无差错接收,即“凡是接收端数据链路层接受的帧,我们都能以非常接近于1的概率认为这些帧在传输过程中没有产生差错”。接收端丢弃的帧虽然曾收到了,但是最终还是因为有差错被丢弃。“凡是接收端数据链路层接收的帧均无差错”。
“可靠传输”:数据链路层发送端发送什么,接收端就收到什么
链路层使用CRC检验,能够实现无比特差错的传输,但这还不是可靠传输。
3.3.2 差错控制(纠错编码)
纠错编码–海明码
海明码:发现双比特错,纠正单比特错。
工作原理:牵一发而动全身
动了一个数据,会使很多个校验码察觉出来,他们之间互相交流,最终会确定哪一位发生了错误。
工作流程:
1.确定校验码的位数r
2.确定校验码和数据的位置
3.求出校验码的值
二进制位数看最后一位到几位,比如10二进制为1010,所以二进制用4位
校验码的值:
P1二进制第四位为1,同样第四位为1的还有D1 D2 D4 D5,我们将他们异或为0即可得到P1。P2 P3 P4同理。
4.检错并纠错
首先我们将所有要校验的位进行异或运算(具体哪几位进行异或见上步)
我们计算后按照 P4 P3 P2 P1排序,本题得到0101,对应十进制5,说明第5位出错,将第5位改为他的反码即可修正