【网络基础】数据链路层实现的三大功能

数据链路层实现的三大功能分别为:

(1) 封装成帧

(2) 透明传输

(3) 差错控制


1、封装成帧

封装成帧就是在一段数据前后分别加入首部和尾部,构成了一个帧。

接收端在收到物理层上交的比特流后。能依据首部跟尾部的标记。从收到的比特流识别帧的開始和结束。

此外,首部跟尾部还包含很多必要的控制信息。

在发送帧时,是从帧首部開始发送。各种数据链路层协议都要对帧首尾部格式有明白的规定。每一种协议都限定了帧的数据部分长度上限-----最大传输单元MTU。

附:最大传输单元MTU(笔者腾讯一面亲历)

一个UDP报文能传输的最大数据为多大?

以太网的数据链路层规定了最大传输单元MTU=1500(字节),那么实际上一个IP数据报最长也就是1500 字节,而IP数据报又是由UDP报文或TCP流封装得到的,那么一个UDP报文最大长度为1500-20=1480.20为IP数 据报的首部长度。

而在运输层。UDP也有自己的首部(8字节),所以在应用层一个UDP报文能传递的最大数据 为1500-20-8=1472(字节)






2、透明传输

什么是透明传输,为什么须要透明传输?看下图:



解决透明传输的方法:

1、发送端的数据链路层在数据中出现控制字符“SOH”或“EOT”的前面插入一个转义字符“ESC”(其十六进制编码是 1B)。


2、字节填充或字符填充——接收端的数据链路层在将数据送往网络层之前删除插入的转义字符
3、假设转义字符也出现数据其中。那么应在转义字符前面插入一个转义字符。当接收端收到连续的两个转义字符时。就删除其中前面的一个。 


实现方法见下图:





3、差错检測

在传输过程中可能会产生比特差错:1 可能会变成 0 而 0 也可能变成 1。
为了保证数据传输的可靠性,在计算机网络数据传输时。必须採用各种差错检測措施。 


CRC循环冗余检測

在数据链路层传送的帧中,广泛使用了循环冗余检验 CRC 的检错技术。


发送端运行的操作:

在发送端,先把数据划分为组。假定每组 k 个比特。

 
如果待传送的一组数据 M = 101001(如今 k = 6)。

我们在 M 的后面再加入供差错检測用的 n 位冗余码一起发送。  

冗余码计算实例:

如今 k = 6, M = 101001。
设 n = 3, 除数 P = 1101,(除数P是我们自己约定的。n的取值是 P的位数减1)
被除数是 (2^n)M = 101001000。

(对M从后開始补0,一共补n位)
模 2 运算的结果是:商 Q = 110101,(计算结果见下图)
            余数 R = 001。
余数 R 作为冗余码加入在数据 M 的后面发送出去。发送的数据是:101001001。共 (k + n) 位。 


CRC 是一种经常使用的检错方法,而 FCS 是加入在数据后面的冗余码。



接收端运行的操作:

从发送端接收到数据M:101001001(包括冗余码FCS)
发送端、接收端约定的除数 P = 1101
M%P 运算结果若为0。表示无比特差错
M%P 运算结果不为0,表示比特差错,丢弃该帧



仅用循环冗余检验 CRC 差错检測技术仅仅能做到无差错接受。“无差错接受”是指:“凡是接受的帧(即不包含丢弃的帧)。我们都能以很接近于 1 的概率觉得这些帧在传输过程中没有产生差错”。

也就是说:“凡是接收端数据链路层接受的帧都没有传输差错”(有差错的帧就丢弃而不接受)。要做到“可靠传输”(即发送什么就收到什么)就必须再加上确认和重传机制。

 


















本文由Cout_Sev 搜集整理并改动

自谢希仁老前辈《计算机网络第5版》

转载请注明出处

谢谢!




原文地址:https://www.cnblogs.com/mfrbuaa/p/5399131.html