计算机网络 —— 数据链路层

news2024/11/15 11:21:21

数据链路层

3.1 数据链路层概述

数据链路层把网络层交下来的数据构成帧发送到链路上,以及把收到的帧数据取出并上交给网络层。链路层属于计算机网络的底层。数据链路层使用的信道主要由以下两种类型:

  1. 点对点通信。
  2. 广播通信。
数据链路和帧

链路:从一个节点到相邻节点的一段物理线路(有线或无线),而中间没有任何其他的交换节点。

数据链路:把实现数据传输的协议的硬件和软件加到链路上,就构成了数据链路。现在最常用的方法是使用网络适配器(既有硬件,也包括软件)来实现这些协议。

一般的适配器都包括了数据链路层和物理层这两层的功能

帧:数据链路层的协议数据单元。

使用点对点信道的数据链路层

数据链路层协议有很多种,但是有三个基本问题原则是共同的。这三个基本问题是:封装成帧、透明传输、差错检查

使用广播信道的数据链路层
  • 共享式以太网的媒体接入控制协议CSMA/CD

  • 802.11局域网的媒体接入控制协议CSMA/CA

数据链路层的互连设备
  • 网桥和交换机的工作原理

  • 集线器(物理层互连设备)与交换机的区别

3.2 封装成帧
封装成帧

封装成帧是指数据链路层给上层交付的协议数据单元添加帧头和帧尾使之称为帧。

  • 帧头和帧尾中包含有重要的控制信息。
  • 帧头和帧尾的作用之一就是帧定界。

在这里插入图片描述

当数据是由可打印的ASCII码组成的文本内容时,帧定界可以使用特殊的帧定界符。ASCII码时7位编码,一共可组合成128个不同的ASCII码,其中可打印的有95个,而不可打印的有33个。控制字符SOH(十六进制是01)放在一帧的最前面,表示帧的首部开始。另一个控制字符EOT(十六进制是04)表示帧的结束。

在这里插入图片描述

假定发送端在尚未发送完一个帧时突然出故障,中断了发送。但随后很快又恢复正常,于是重新从头开始发送刚才未发送完的帧。由于使用了帧定界符,接收端就知道前面收到的数据是个不完整的帧,必须丢弃。而后面收到的数据有明确的帧定界符(SOH和EOT),因此这是一个完整的帧,应当收下。

透明传输

透明传输是指数据链路层对上层交付的传输数据没有任何限制,就好像数据链路层不存在一样。

  • 面向字节的物理链路使用字节填充(或称字符填充)的方法实现透明传输。
  • 面向比特的物理链路使用比特填充的方法实现透明填充。

当传送的帧时文本文件组成的帧时(文本文件中的字符都是从键盘上输入的),其数据部分显然不会出现像SOH或EOT这样的帧定界控制符。从键盘上不管输入什么字符串都可以放在这样的帧中传输过去,因此这样的传输就是透明传输。

当数据是非ASCII码的文本文件时(如二进制代码的计算机程序或图像等),情况就会有所不同。如果数据中的某个字节的二进制代码恰好和SOH或EOT这种控制字符一样,数据链路层就会中断,把剩下的数据丢下。

在这里插入图片描述

解决方法:

字节填充

发送端地数据链路层在数据中出现控制字符“SOH”或“EOT”的前面插入一个转义字符“ESC”(其十六进制是1B,二进制是00011011)。而在接收端的数据链路层在把数据送往网络层之前删除这个插入的转义字符。这种方法称位字节填充字符填充

在这里插入图片描述

比特填充

在发送前可以采用零比特填充法,对数据部分进行扫描,每5个连续1后面就插入一个比特0,这样就确保了帧定界在整个帧中的唯一性。

接收方的数据链路层在提取帧时,将帧的数据部分中的每5个连续的比特1后面的那个比特0剔除即可。

在这里插入图片描述

为了提高帧的传输效率,应当使帧的数据部分的长度尽可能大些。考虑到差错控制等多种因素,每一种数据链路层协议都规定了帧的数据部分的长度上限,即最大传送单元MTU(Maximum Transfer Unit)。

在这里插入图片描述

3.3 差错检验

传输差错可分为两大类:

  1. 比特差错
  2. 传输差错
比特差错

比特在传输过程中可能会出现差错:1可能会变成0,而0也可能会变成1,这就叫做比特差错。在一段时间内传输错误的比特占所传输比特总数的比率称为误码率。为了保证数据传输的可靠性,在计算机网络传输数据时,必须采用各种差错检查措施,目前在数据链路层广泛使用了循环冗余检测 CRC的检错技术。

循环冗余校验CRC:

  1. 收发双方约定好一个生成多项式G(x);
  2. 发送方基于待发送的数据和生成多项式计算出冗余码FCS,将其添加到待传输数据的后面一起传输;
  3. 接收方通过生成多项式来计算收到的数据是否产生了误码;

在数据链路层,发送端帧检测序列FCS的生成和接收端的CRC检验都是用硬件完成的,处理很迅速,因此并不会耽误数据的传输。

传输差错

传输差错分为帧丢失、帧重复或帧失序

假设,在发送放连续传送三个帧:【#1】、【#2】、【#3】

  1. 帧丢失:收到【#1】、【#3】
  2. 帧重复:收到 【#1】、【#2】、【#2】、【#3】
  3. 帧失序:收到【#1】、【#3】、【#2】
3.4 可靠传输
3.4.1 基本概念

数据链路层向上层提供的服务类型:

  • 不可靠传输服务:仅仅丢弃有误码的帧,其他什么也不做。
  • 可靠传输服务:想办法实现发送什么,接收端就收到什么。

一般情况下,有线链路的误码率比较低,为了减小开销,并不要求数据链路层向上提供可靠传输服务。即使出现了误码,可靠传输的问题由其上层处理。

无线链路易受干扰,误码率比较高,因此要求数据链路层必须向上层提供可靠传输服务。

3.4.2 实现机制 —— 停止- 等待协议SW(Stop - and -Wait)

停止等待就是每发送完一个分组就停止发送,等待对方的确认。在收到确认后再发送下一个分组。

在这里插入图片描述

  • 接收端检测到数据分组有误码时,将其丢弃并等待发送方的超时重传。但对于误码率较高的点对点链路,为使发送方尽早重传,也可给发送方发送NAK分组。
  • 为了让接收方能够判断所收到的数据分组是否是重复的,需要给数据分组编号。由于停止-等待协议的停等特性,只需1个比特编号就够了,即编号0和1。
  • 为了让发送方能够判断所收到的ACK分组是否是重复的,需要给ACK分组编号,所用比特数量与数据分组编号所用比特数量一样。数据链路层一般不会出现ACK分组迟到的情况,因此在数据链路层实现停止-等待协议可以不用给ACK分组编号。
  • 超时计时器设置的重传时间应仔细选择。一般可将重传时间选为略大于“从发送方到接收方的平均往返时间”
    • 在数据链路层点对点的往返时间比较确定,重传时间比较好设定。
    • 然而在运输层,由于端到端往返时间非常不确定,设置合适的重传时间有时并不容易。

停止-等待协议信道利用率:

在这里插入图片描述

当往返时延RTT远大于数据帧发送时延TD时(例如使用卫星链路),信道利用率非常低。若出现重传,则对于传送有用的数据信息来说,信道利用率还要降低。

为了克服停止-等待协议信道利用率很低的缺点,就产生了另外两种协议,即回退N帧协议GBN和选择重传协议SR

3.4.3 实现机制 —— 回退N帧协议GBN(Go - Back - N)

回退N帧协议允许发送方连续发送多个帧(即发送窗口可以大于1),以解决停等协议信道利用率低的问题。

发送方可在未收到接收方确认分组的情况下,将序号落在发送窗口内的多个数据分组全部发送出去;但接收方的接收窗口大小仅为1,也就是只有接收到了此窗口所代表的序号的分组,接收方才会回复ACK并且移动接收窗口。同理,发送方收到了发送窗口中最早的那个序号对应分组的ACK,才会移动发送窗口。

在这里插入图片描述

接收方不一定要对收到的数据分组逐个发送确认,而是可以在收到几个数据分组后(由具体实现决定)对按序到达的最后一个数据分组发送确认。ACKn表示序号为n及以前的所有数据分组都已正确接收。

在这里插入图片描述

当通信线路质量不好时,GBN协议并不比SW协议效率高。

3.4.4 实现机制 —— 选择重传协议SR(Selective Request)

回退N帧协议的接收窗口尺寸 W R W_R WR只能等于1,因此接收方只能按序接收正确到达的数据分组

一个数据分组的误码就会导致其后续多个数据分组不能被接收方按序接收而丢弃(尽管它们无乱序和误码)。这必然会造成发送方对这些数据分组的超时重传,显然这是对通信资源的极大浪费。

为了进一步提高性能,可设法只重传出现误码的数据分组。因此,接收窗口的尺寸 W R W_R WR不应再等于1(而应大于1),以便接收方先收下失序到达但无误码并且序号落在接收窗口内的那些数据分组,等到所缺分组收齐后再一并送交上层。这就是选择重传协议。

在这里插入图片描述

3.5 点对点协议PPP

互联网用户通常都要连接到某个ISP才能接入到互联网。PPP协议就是用户计算机和ISP进行通信时所使用的数据链路层协议。

在这里插入图片描述

3.5.1 PPP协议应满足的需求

(1)简单

(2)封装成帧

(3)透明性

(4)多种网络层协议

(5)多种类型链路

(6)差错检测

(7)检测连接状态

(8)最大传送单元

(9)网络层地址协商

(20)数据压缩协商

3.5.2 PPP协议的帧格式
(1)各字段的意义

PPP帧的首部和尾部分别为四个字段和两个字段。

F7E:表示一个帧的开始或结束

A FF:地址字段(没有携带PPP帧的信息)

C03:控制字段(没有携带PPP帧的信息)

协议:当协议字段为 0 x 0021时,PPP帧的信息字段就是 IP 数据报。若为 0 x C021,则信息字段时PPP链路控制协议LCP的数据,而 0 x 8021表示这是网络层的控制数据

信息部分:信息字段的长度使可变的,最多不超过1500字符

FCS:使用CRC的帧检验序列FCS

在这里插入图片描述

当信息字段中出现和标志字段一样的比特组合时,就必须采取一些措施使这种形式上和标志字段一样的比特组合不出现在信息字段里

(2)字节填充

当PPP使用异步传输时,我们使用0x7D(01111101)作为转义符,转义的规则如下:

  • 把信息字段中出现的每一个0x7E字节转变为2字节序列(0x7D,0x5E)。
  • 若信息字段中出现一个0x7D的字节(即出现了和转义字符一样的比特组合),则把转义字符0x7D转变为2字节序列(0x7D,0x5D)。
  • 若信息字段中出现ASCII码的控制字符(即数值小于0x20的字符),则在该字符前面要加入一个0x7D字节,同时将该字符的编码加以改变。例如,出现0x03(在控制字符中是“传输结束”ETX)就要把它转变为2字节序列的(0x7D,0x31)。
(3) 零比特填充

PPP协议在同步传输时,采用零比特填充方式来实现透明传输

零比特填充法的具体做法是:在发送端,当一串比特流尚未加上标志字段时,先用硬件扫描整个帧。只要发现5个连续1,则立即填入一个0。因此经过这种零比特填充后的数据,就可以保证不会出现6个连续1。在接收一个帧时,先找到F字段以确定帧的边界。接着再用硬件对其中的比特流进行扫描。每当发现5个连续1时,就将这5个连续1后的一个0删除,以还原成原来的比特流。这样就保证了在所传送的比特流中,不管出现什么样的比特组合,也不至于引起帧边界的判断错误。

3.6 媒体接入控制
3.6.1 基本概念

共享信道要着重考虑的一个问题就是如何协调多个发送和接受站点对一个共享传输媒体的占用,即媒体介入控制MAC(Medium Access Control)。

在这里插入图片描述

媒体接入控制可分为静态划分信道、动态接入控制:

在这里插入图片描述
5139770502)

3.6.2 静态划分信道

信道复用

复用就是通过一条物理线路同时传输多路用户的信号。当网络中传输媒体的传输容量大于多条单一信道传输的总通信量时,可利用复用技术在一条物理线路上建立多条通信信道来充分利用传输媒体的带宽。

在这里插入图片描述

常见的信道复用技术有:频分复用FDM、时分复用TDM、波分复用WDM、码分复用CDM。

频分复用FDM

将传输线路的频带资源划分成多个子频带,形成多个子信道,各子信道之间需要留出隔离频带,以免造成子信道间的干扰。当多路信号输入一个多路复用器时,这个复用器将每一路信号调制到不同频率的载波上。接收端由相应的分用器通过滤波将各路信号分开,将合成的服用信号恢复成原始的多路信号。

在这里插入图片描述

时分复用TDM

时分复用技术将传输线路的带宽资源,按时隙轮流分配给不同的用户,每对用户只在所分配的时隙里使用线路传输数据。

时分复用技术将时间划分成了一段段等长的时分复用帧。每一个时分复用的用户在每一个时分复用帧中占用固定序号的时隙。

每一个用户所占用的时隙是周期性出现的,其周期就是时分复用帧的长度。

在这里插入图片描述

波分复用WDM

波分复用是利用多个激光器在单条光纤上同时发送多束不同波长激光的技术。每个信号经过数据(文本、语音、视频等)调制后都在它独有的色带内传输。

在这里插入图片描述

码分复用CDM

码分复用CDM是另一种共享信道的方法。实际上,由于该技术主要用于多址接入,更常用的名词是码分多址CDMA(Code Division Multiple Access)。

复用和多址的区别:

  • 复用是将单一媒体的频带资源划分成很多子信道,这些子信道之间相互独立,互不干扰。从媒体的整体频带资源上看,每个子信道只占用该媒体频带资源的一部分。
  • 多址(更确切地应该称为多点接入)处理的是动态分配信道给用户。这在用户仅仅暂时性地占用信道的应用中是必须的,而所有的移动通信系统基本上都属于这种情况。相反,在信道永久性地分配给用户的应用中,多址是不需要的(对于无线广播或电视广播站就是这样)。

在CDMA中,每一个比特时间再划分为m个短的间隔,称为码片(Chip)。通常m的值是64或128。为了简单起见,在后续的举例中,我们假设m为8。

使用CDMA的每一个站被指派一个唯一的m bit码片序列利(Chip Sequence)。

  • 一个站如果要发送比特1,则发送它自己的m bit码片序列;
  • 一个站如果要发送比特0,则发送它自己的m bit码片序列的二进制反码;

码片序列的挑选原则如下:

  1. 分配给每个站的码片序列必须各不相同,实际常采用伪随机码序列。
  2. 分配给每个站的码片序列必须相互正交(规格化内极为0)。
3.6.3 随机接入控制 —— CSMA/CD 协议

总线局域网使用的协议:CSMA/CD

在这里插入图片描述

3.6.4 随机接入控制 —— CSMA/CA 协议

无线局域网使用的协议:CSMA/CA

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3.7 MAC地址、IP地址以及APR协议

在这里插入图片描述

3.8 集线器与交换机区别

在这里插入图片描述

在这里插入图片描述

3.9 以太网交换机学习和转发帧的流程

在这里插入图片描述

3.10 以太网交换机的生成树协议STP

在这里插入图片描述

3.11 虚拟局域网VLAN
3.11.1 概述

在这里插入图片描述

3.11.2 实现机制

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1380841.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

国足2024亚洲杯首战!Python爬取每场比赛双方球队的近期交战战绩

一、爬取目标 二、完整源码 #""""""""""""""""""""""""""""""""""""""…

30 树的定义

树的定义 树的度?叶节点? 注意:k为叶节点 孩子/双亲/子孙/祖先 树的高度? 有序树 森林 树的一些操作: 粗略的框架代码: 省略。。。 小结: 树是线性表的扩展

vcruntime140.dll已加载,但找不到入口点的处理方法分享

当遇到错误提示“vcruntime140.dll已加载,但找不到入口点”时,很多人可能会感到困惑,不知道如何去处理这个问题。不过没有必要紧张,在这里我会为大家详细解释 vcruntime140.dll 文件是什么,并指导大家如何高效地解决 v…

2024年中职网络安全——Windows操作系统渗透测试(Server2105)

Windows操作系统渗透测试 任务环境说明: 服务器场景:Server2105服务器场景操作系统:Windows(版本不详)(封闭靶机)需要环境加Q 目录 1.通过本地PC中渗透测试平台Kali对服务器场景进行系统服务…

让网页自动化测试更简便,流程图设计工具为您解决痛点

在数字化时代,网页自动化测试已经成为提高工作效率、保证项目质量的重要手段。然而,传统的自动化测试往往需要复杂的编程技能,对非专业人员来说门槛较高。为了解决这个问题,我们向您推荐一款创新的设计工具,它可以通过…

好大夫问诊数据爬虫记录

好大夫问诊数据爬虫入库字段记录 获取医生的病程列表 uid Column(Integer, primary_keyTrue, autoincrementTrue) gender Column(String(10)) # 性别 age Column(Integer) # 年龄 # 总交流次数 total_communication_times Column(Integer) # 医生回复次数 doctor_reply_t…

代码随想录算法训练营第四天 | 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题 02.07. 链表相交、142.环形链表II

代码随想录算法训练营第四天 | 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题 02.07. 链表相交、142.环形链表II 文章目录 代码随想录算法训练营第四天 | 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点、面试题 02.07. 链表相交、142.环形链表II1 Le…

解密威胁:.kat6.l6st6r 勒索病毒的威胁与恢复

导言: 在当今数字化时代,勒索病毒已经成为网络安全威胁中的一大巨头。其中,.kat6.l6st6r 勒索病毒以其狡猾的传播方式和高级的加密算法备受关注。本文将深入介绍.kat6.l6st6r 勒索病毒的特点、应对措施以及如何预防此类威胁。如果您在面对被…

国内镜像:极速下载编译WebRTC源码(For Android/Linux/IOS)(二十四)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 人生格言: 人生从来没有捷径,只…

视频剪辑达人分享:批量减片时时长并调整播放倍速的技巧

在视频剪辑中,经常要对多个视频片段进行时长调整和播放倍速的修改。如果一个个手动操作,不仅效率低下,还容易出错。如何快速批量处理这些片段呢?现在一起来看看云炫AI智剪批量减片时长并调整播放的具体步骤。 原视频和剪辑后的视…

HarmonyOS@Observed装饰器和@ObjectLink装饰器:嵌套类对象属性变化

Observed装饰器和ObjectLink装饰器:嵌套类对象属性变化 上文所述的装饰器仅能观察到第一层的变化,但是在实际应用开发中,应用会根据开发需要,封装自己的数据模型。对于多层嵌套的情况,比如二维数组,或者数…

从DETR到Mask2Former(1):DETR-segmentation结构全解析

网上关于DETR做的detection的解析很多,但是DETR做Segmentation的几乎没有,本文结合DETR的论文与代码,对DETR做一个详细的拆解。理解DETR是理解Mask2Former的基础。 首先得把DETR-segmentation给run起来。Github上DETR的repository&#xff0…

Ubuntu下AI4Green开源ELN服务的简单部署

主部署程序:AI4Green 配置参考这篇文档:AI4Green开源ELN(电子实验记录本)-CSDN博客 流量转发和负载均衡:使用Nginx 配置参考这篇文档:Nginx负载均衡-CSDN博客 SSL配置部分参考这篇文档: 设置…

案例119:基于微信小程序的宿舍管理系统设计与实现

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

[NSSCTF Round#16 Basic] CPR

打着玩玩,比赛很简单。 Crypto pr 一个RSA题,n1p*q,n2q*r给了两个c和p,r而且flag经过pad用单因子无法解出。分别用p,r解完再取crt from Crypto.Util.number import * import randomflagplaintext NSSCTF{****************} charset abcdefghijklmn…

Mnajora 使用deb包安装软件

说明 Mnajora 安装deb软件包主要有两种方式 可以使用dpkg 直接安装也可是使用debtap将deb软件包转换成 使用dpkg sudo pacman -S dpkg #安装dpkgsudo dpkg -i ###.deb #使用dpkg安装deb软件包和在ubuntu上是一样的 安装成功 使用debtap debtap是一个用于将.deb包转换为A…

CSS伪类:为网页增添交互和样式

CSS伪类是一项强大的特性,它允许开发者根据不同的状态、位置和结构选择器来选择和样式化HTML元素。通过使用CSS伪类,我们可以为网页增添交互性、响应性和样式化效果。本文将深入探讨CSS伪类的概念、常见用法和一些实用示例。 CSS伪类是什么 CSS伪类是一…

class_2:using namespace std命名空间

1、标准命名空间:using namespace std; std包含了基本的类、数据对象、函数等,如cin ,cout,endl等,如果在代码没有声明 using namespace std;则需要再调用这些接口的时候需要显示的声明,例如:std::cin等&…

从混沌到有序:2023年全球软件质量与效能大会中的运维经验分享

在当今这个信息化社会,软件已经成为了我们生活和工作中不可或缺的一部分。然而,随着软件应用的普及和复杂度的增加,如何保障软件的质量和效能已经成为了一个重要的问题。 2023年全球软件质量与效能大会(QECon上海站)汇…

PLC数组队列搜索FC(SCL代码+梯形图程序)

根据输入数据搜索输入数据队列中和输入数据相同的数,函数返回其所在队列的位置。这里我们需要用到博途PLC的数组指针功能,有关数组指针的详细使用方法,可以参考下面文章: 博途PLC数组指针: https://rxxw-control.blog.csdn.net/article/details/134761364 区间搜索FC …