亲宝软件园·资讯

展开

计算机网络 - 数据链路层

农夫三拳有点疼~ 人气:2
# 数据链路层概述 ## 基本概念 ### 数据发送模型: ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312172149.png) ### 数据链路层的信道类型: - 点对点信道:这种信道使用一对一的点对点通信方式。 - 广播信道。这种信道使用一对多的广播通信方式,因此过程比较复杂。广播信道上连接的主机很多,因此必须使用专用的共享信道协议来协调这些主机的数据发送。 ### 链路和数据链路: - 链路(link):是一条点到点的物理线路段,中间没有任何其他的点,**一条链路只是一条通路的一个组成部分**。 - 数据链路(data link):除了物理线路外,还必须有通信协议来控制这些数据的传输。若把实现这些协议的硬件和软件加到链路上,就构成了数据链路。 - 现最常用的方法是使用适配器(即网卡)来实现这些协议的硬件和 软件。 - 一般的适配器都包括了数据链路层和物理层这两层的功能。 ### 帧: 数据链路层传送的是帧 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312173214.png) ### 数据链路层就像一个数字管道 常常在两个对等的数据链路层之间画出一个数字管道,而在这条数字管道上传输的数据单位是帧。 ## 要解决的三个基本问题 ### 封装成帧 - 封装成帧就是在一段数据的前后分别添加首部和尾部,然后就构成了一个帧,用以确定帧的界限。 - 首部和尾部的一个重要作用就是进行帧定界。 - 如果发送端发送时出现故障,接收端没收到完整的头和尾,就会将帧丢掉 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312173853.png) ### 透明传输 若传输的数据是ASCI I码中“可打印字符(共95个)”集时,一切正常。 若传输的数据不是仅由“可打印字符”组成时,就会出问题,如下图 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312174904.png) 我们可以使用**字节填充法**解决透明传输的问题: - 发送端的数据链路层在数据中出现控制字符“SOH”或“EOT”的前面插入一个字符“ESC” (其十六进制编码是1B) - 字节填充(byte stuffing)或字符填充(character stuffing)——接收端的数据链路层在将数据送往网络层之前删除插入的转义字符。 - 如果转义字符也出现数据当中,那么应在转义字符前插入一个转义字符。当接收端收到连续的两个转义字符时,就删除其中前面的一个。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312175652.png) ### 差错控制 - 传输过程中可能会产生**比特差错**:1可能会变成0而0也可能变成1。 - 在一段时间内,传输错误的比特占所传输比特总数的比率称为 **误码率** BER (Bit Error Rate) 。 - 误码率与信噪比有很大的关系。 - 为了保证数据传输的可靠性,在计算机网络传输数据时,必须采用各种差错检测措施。 我们可以使用 **循环冗余检测** **CRC** ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200312181331.png) 仅用循环冗余检验CRC差错检测技术只能做到**无差错接受**(accept)。 - “无差错接受” 是指:“凡是接受的帧( 即不包括丢弃的帧),我们都能以非常接近于1的概率认为这些帧在传输过程中没有产生差错”。也就是说:“凡是接收端数据链路层接受的帧都没有传输差错”(有差错的帧就丢弃而不接受)。 要做到 “可靠传输” (即发送 什么就收到什么)就必须再加上确认和重传机制。 - 考虑:帧重复、帧丢失、帧乱序的情况 可以说 “CRC是一种无比特差错,而不是无传输差错的检测机制” - OSI/RM模型的观点:数据链路层要做成无传输差错的,但这种理念目前不被接受! # 使用点对点信道的数据链路层(PPP协议) ## PPP协议 现在全世界使用的最多的数据链路层协议就是 **点对点协议** 即 **PPP协议(Pointer to Pointer Protocol)**,用户使用拨号电话线接入因特网时,一般都是使用PPP协议。 ## PPP协议的使用场合 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200313213420.png) | PPP协议应该满足的要求 | PPP协议不需要满足的要求 | | :-------------------: | :---------------------: | | 简单——这是首要的要求 | 纠错 | | 封装成帧 | 流量控制 | | 透明性 | 序号 | | 多种类型链路 | 多点线路 | | 差错检测 | 半双工或单工链路 | | 检测连接状态 | | | 最大传送单元 | | | 网络层地址协商 | | | 数据压缩协商 | | ## PPP协议的组成 - 数据链路层协议可以用于异步串行或同步串行介质。 - 它使用LCP (链路控制协议)建立并维护数据链路连接。 - 网络控制协议(NCP)允许在点到点连接上使用多种网络层协议,如图所示 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200313215356.png) ## PPP协议帧格式 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200313223120.png) ## 字节填充 **问题:信息字段中出现了标志字段的值,可能会被误认为是“标志位”怎么办?** - 将信息字段中出现的每个0x7E字节转变成为2字节序列(0x7D,0x5E)。 - 若信息字段中出现一个0x7D的字节,则将其转变成为2字节序列(0x7D,0x5D)。 - 若信息字段中出现ASCII 码的控制字符(即数值小于0x20的字符),则在该字符前面要加入一个0x7D字节,同时将该字符的编码加以改变。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200313223504.png) ## 零比特填充 PPP 协议用在 SONET/SDH 链路时,使用同步传输(一连串的比特连续传送)。这时 PPP 协议采用零比特填充方法来实现透明传输。 在发送端,只要发现有 **5 个连续 1**,则立即**填入一个0**。 接收端对帧中的比特流进行扫描。每当发现 5 个连续1时,就把这 **5 个连续 1 后的一个 0 删除** ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200313223650.png) ## PPP协议工作状态 当用户拨号接入ISP 时,路由器的调制解调器对拨号做出确认,并建立一条物理连接。 PC机向路由器发送一系列的LCP分组(封装成多个PPP帧)。 这些分组及其响应选择一些PPP参数,和进行网络层配置,NCP给新接入的PC机分配一个临时的IP地址,使PC机成为因特网上的一个主机。 通信完毕时,NCP 释放网络层连接,收回原来分配出去的IP地址。接着,LCP释放数据链路层连接。最后释放的是物理层的连接。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200314221850.png) # 使用广播信道的数据链路层(CSMA/CD协议) ## 局域网的拓扑 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200315113905.png) ## 局域网的特点与优点 局域网最主要的特点是: - 网络为一个单位所拥有,且地理范围和站点数目均有限。 局域网具有如下的一些主要优点: - 具有广播功能,从一个站点可很方便地访问全网。局域网上的主机可共享连接在局域网上的各种硬件和软件资源。 - 便于系统的扩展和逐渐地演变,各设备的位置可灵活调整和改变。 - 提高了系统的可靠性、可用性和生存性。 ## 共享通信媒体 ### 静态划分信道 - 频分复用 - 时分复用 - 波分复用 - 码分复用 ### 动态媒体接入控制(多点接入) - 随机接入(主要被以太网采用! ) - 受控接入,如多点线路探询(polling),或轮询。(目前已不被采用) ## 认识以太网 > 最初的以太网是将许多计算机都连接到一根总线上。当初认为这样的连接方法既简单又可靠,因为总线上没有有源器件。但是不安全,有可能被非目标计算机抓包 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200315115342.png) 总线上的每一个工作的计算机都能检测到B发送的数据信号。 由于只有计算机D的地址与数据帧首部写入的地址一致,因此只有D才接收这个数据帧。 其他所有的计算机(A,C和E)都检测到不是发送给它们的数据帧,因此就丢弃这个数据帧而不能够收下来。 具广播特性的总线上实现了一对一的通信。 ## 载波监听多点接入/碰撞检测 (CSMA/CD)协议 > CSMA/CD表示Carrier Sense Multiple Access with Collision Detection。 ### 载波监听多点接入 **“多点接入”**表示许多计算机以多点接入的方式连接在一根总线上。 **“载波监听”**是指每一个站在发送数据之前先要检测一下总线 上是否有其他计算机在发送数据,如果有,则暂时不要发送数据,以免发生 碰撞。“载波监听”就是用电子技术检测总线上有没有其他计算机发送的数据信号。 ### 碰撞检测 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316141740.png) “碰撞检测” 就是计算机边发送数据边检测信道上的信号电压大小 - 当几个站同时在总线上发送数据时,总线上的信号电压摆动值将会增大(互相叠加) - 当一个站检测到的信号电压摆动值超过一定的门限值时,就认为总线上至少有两个站同时在发送数据,表明产生了**碰撞**。 - 所谓“碰撞”就是发生了冲突。因此“碰撞检测”也称为**“冲突检测”**。 **检测到碰撞后:** - 在发生碰撞时,总线上传输的信号产生了严重的失真,无法从中恢复出有用的信息来。 - 每一个正在发送数据的站,一旦发现总线上出现了碰撞,就要立即停止发送,免得继续浪费网络资源,然后等待一段随机时间后再次发送。 ### 争用期 最先发送数据帧的站,在发送数据帧后至多经过时间**2τ** ( 两倍的端到端的往返时延)就可知道发送的数据帧是否遭受了碰撞。**经过争用期这段时间还没有检测到碰撞,才能肯定这次发送不会发生碰撞。** #### 以太网的争用期 - 以太网的端到端往返时延2τ称为争用期,或碰撞窗口。通常,取51.2 μs为争用期的长度。 - 对于10 Mb/s以太网,在争用期内可发送512 bit, 即64字节。 - 以太网在发送数据时,若前64字节未发生冲突,则后续的数据就不会发生冲突。 #### 最短有效帧长 - 如果发生冲突,就一定是在发送的前**64字节之内**。 - 由于一检测到冲突就立即中止发送,这时已经发送出去的数据一定小于64字节。 - **以太网**规定了**最短有效帧长为64字节**,凡长度小于64字节的帧都是由于冲突而异常中止的无效帧。 ### 二进制指数类型退避算法 发生碰撞的站在停止发送数据后,要推迟(退避) 一个随机时间才能再发送数据。 - 确定基本退避时间,一般是取为争用期2τ。 - 定义参数k,k = Min[重传次数, 10] - 从整数集合[0,1,...,(2^k -1)]中随机地取出一个数,记为 г 。 重传所需的时延就是r倍的基本退避时间。当重传达16次仍不能成功时即丢弃该帧,并向高层报告。 # 以太局域网(以太网) ## 以太网的两个标准 - DIX Ethernet V2 是世界上第一个局域网产品(以太网)的规约 - IEEE 的802.3标准。 - DIX Ethernet V2标准与IEEE 的802. 3标准只有很小的差别,因此可以将802. 3局域网简称为**“以太网”**。严格说来,“以太网” 应当是指符合DIX Ethernet V2标准的局域网。 ## 以太网与数据链路层的两个子层 为了使数据链路层能更好地适应多种局域网标准,802委员会就将局域网的数据链路层拆成两个子层: - 逻辑链路控制LLC (Logical Link Control)子层 - **媒体接入控制MAC (Medium Access Control)子层。** 与接入到传输媒体有关的内容都放在MAC子层,而LLC子层则与传输媒体无关,不管采用何种协议的局域网对LLC子层来说都是透明的。 由于TCP/IP体系经常使用的局域网是DIX Ethernet V2而不是802.3标准中的几种局域网,因此现在802委员会制定的逻辑链路控制子层LLC (即802. 2标准)的作用已经不大了。很多厂商生产的适配器上就仅装有**MAC协议**而没有LLC 协议。 ## 星型拓扑 > 传统以太网最初是使用粗同轴电缆,后来演进到使用比较便宜的细同轴电缆,最后发展为使用更便宜和更灵活的双绞线。不用电缆而使用无屏蔽双绞线。每个站需要用两对双绞线,分别用于发送和接收。 > 这种以太网采用**星形拓扑**,在星形的中心则增加了一种可靠性非常高的设备, > 叫做**集线器(hub)**。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316143941.png) ### 集线器的一些特点: 集线器是使用电子器件来模拟实际电缆线的工作,**因此整个系统仍然像一个传统的以太网那样运行**。集线器使用了大规模集成电路芯片,因此这样的硬件设备的可靠性已大大提高了。 使用集线器的以太网在逻辑上仍是一个总线网,各工作站使用的还是**CSMA/CD协议**,并共享逻辑上的总线。 集线器很像一个多接口的转发器,**工作在物理层**。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316144454.png) ## 以太网的信道利用率 以太网的信道被占用的情况: - 争用期长度为2τ,即端到端传播时延的两倍。检测到碰撞后不发送干扰信号。 - 帧长为L (bit), 数据发送速率为C (b/s),因而帧的发送时间为L/C = T₀ (s) ---- 一个帧从开始发送,经可能发生的碰撞后,将再重传数次,到发送成功且信道转为空闲(即再经过时间τ使 得信道上无信号在传播)时为止,是发送一帧所需的平均时间。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316145321.png) #### 以太网的信道利用率:参数a - 要提高以太网的信道利用率,就必须减小 τ 与 T₀ 之比。在以太网中定义了参数a,它是以太网单程端到端时延τ与帧的发送时间 T₀ 之比: $$a = \frac τ {T₀}$$ - a- >0表示一发生碰撞就立即可以检测出来,并立即停止发送,因而信道利用率很高。 - a越大,表明争用期所占的比例增大,每发生一次碰撞就浪费许多信道资源,使得信道利用率明显降低。 #### 以太网的信道利用率:最大值 **对以太网参数的要求** - 当数据率一定时,以太网的连线的长度受到限制,否则 τ 的数值会太大 - 以太网的帧长不能太短,否则 T₀ 的值会太小,使 a 值太大。 **信道利用率的最大值** - 在理想化的情况下,以太网上的各站发送数据都不会产生碰撞(这显然 已经不是CSMA/CD, 而是需要使用一种特殊的调度方法),即总线一旦 空闲就有某一个站立即发送数据。 - 发送一帧占用线路的时间是 T₀+ t,而帧本身的发送时间是 T₀,于是 我们可计算出理想情况下的极限信道利用率$S_{max}$为: ## MAC层的硬件地址(MAC地址) 在局域网中,**硬件地址**又称为**物理地址**,或 **MAC地址**。 802 标准所说的 “地址” 严格地讲应当是每一个站的 “**名字**” 或 **标识符**。但鉴于大家都早已习惯了将这种48位的“名字”称为“地址”,所以本文也采用这种习惯用法,尽管这种说法并不太严格。 - IEEE的注册管理机构RA负责向厂家分配地址字段的前三个字节(即高位24位)。 - 地址字段中的后三个字节(即低位24位)由厂家自行指派,称为**扩展标识符**,必须保证生产出的适配器没有重复地址。 - 一个地址块可以生成2²⁴个不同的地址。这种**48位**地址称为MAC- 48,它的通用名称是EUI-48。 - “MAC地址” 实际上就是适配器地址或适配器标识符EUI-48。 > 在同一个交换机上的计算机MAC地址不可相同,否则会产生网络故障,MAC地址可以手动修改 ## 适配器检查 MAC 地址 **适配器从网络上每收到一个MAC帧就首先用硬件检查MAC帧中的MAC地址** - 如果是发往本站的帧则收下,然后再进行其他的处理。 - 否则就将此帧丢弃,不再进行其他的处理。 **“发往本站的帧”包括以下三种帧:** - 单播(unicast)帧(一对一 ) - 广播(broadcast)帧(一对全体) - 多播(multicast)帧(一对多) ## MAC 帧格式 常用的以太网MAC帧格式有两种标准: - DIX Ethernet V2 标准 - IEEE 的 802.3 标准 最常用的MAC帧是**以太网V2**的格式。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316153643.png) ## 无效的 MAC 帧 - 帧的长度不是整数个字节; - 用收到的帧检验序列FCS 查出有差错; - 数据字段的长度不在 46 ~ 1500 字节之间。 - 有效的MAC帧长度为 64 ~ 1518 字节之间。 - 对于检查出的无效MAC帧就简单地丢弃。以太网不负责重传丢弃的帧。 ## 帧间最小间隔 - 帧间最小间隔为9.6 μs,相当于96 bit的发送时间。 - 一个站在检测到总线开始空闲后,还要等待9.6 μs才能再次发送数据。 - 这样做是为了使刚刚收到数据帧的站的接收缓存来得及清理,做好接收下一帧的准备。 # 扩展以太网 ## 在物理层考虑扩展 - 主机使用光纤和一对光纤调制解调器连接到集线器 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316215523.png) - 用一个集线器连接多个集线器(数量不宜超过30台计算机,连接越多,效率越低) ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316220050.png) ## 在数据链路层考虑扩展 - 在数据链路层扩展局域网是使用**网桥**。 - 网桥工作在数据链路层,它根据**MAC帧的目的地址**对收到的帧进行转发。 - 网桥具有过滤帧的功能。当网桥收到一个帧时,并不是向所有的接口转发此帧,而是**先检查**此帧的目的MAC地址,然后**再确定**将该帧转发到哪一个接口。 ### 网桥的内部结构 ![image-20200316220739181](assets/image-20200316220739181.png) ### 使用网桥扩展以太网 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316221141.png) ### 网桥扩展以太网的优缺点 优点: - 过滤通信量。 - 扩大了物理范围。 - 提高了可靠性。 - 可互连不同物理层、不同MAC子层和不同速率(如10 Mb/s和100Mb/s以太网)的局域网。 缺点: - 存储转发增加了时延。 - 在MAC子层并没有流量控制功能。 - 具有不同MAC子层的网段桥接在一起时时延更大。 - 网桥只适合于**用户数不太多**(不超过几百个)和**通信量不太大**的局域网,否则有时还会因传播过多的广播信息而产生网络拥塞。这就是所谓的广播风暴。 ### 透明网桥 - 目前使用得最多的网桥是**透明网桥**(transparent br idge)。 - “透明”是指局域网上的站点并不知道所发送的帧将经过哪几个网桥,**因为网桥对各站来说是看不见的**。 - 透明网桥是一种**即插即用设备**,其标准是IEEE 802.1D ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316222743.png) ### 网桥的自学习算法 - 若从 A 发出的帧从接口 x 进入了某网桥,那么从这个接口出发沿相反方向一定可把一个帧传送到 A 。 - 网桥每收到一个帧,就记下其源地址和进入网桥的接口,作为转发表中的一个项目。 - 在建立转发表时是把帧首部中的源地址写在 “地址” 这一栏的下面。 - 在转发帧时,则是根据收到的帧首部中的目的地址来转发的。这时就把在“地址”栏下面已经记下的源地址当作目的地址,而把记下的进入接口当作转发接口。 ## 用交换机扩展以太网 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316224129.png) ## 虚拟局域网 ### LAN和VLAN - 交换机的使用使得VLAN的创建成为可能 - 虛拟局域网VLAN是由一些局域网网段构成的与物理位置无关的逻辑组。 - 这些网段具有某些共同的需求。 - 每一个VLAN的帧都有-个明确的标识符,指明发送这个帧的工作站是属于哪一个VLAN。 - 虚拟局域网其实只是局域网给用户提供的一种服务,而并不是一种新型局域网。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316230316.png) ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316231731.png) ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316232359.png) ### 虚拟局域网枕格式 虚拟局域网协议允许在以太网的帧格式中插入一个4字节的标识符,称为VLAN 标记(tag),用来指明发送该帧的工作站属于哪一个虚拟局域网。 ![](https://gitee.com/songjilong/FigureBed/raw/master/img/20200316232731.png) # 高速以太网 ## 100BASE-T 速率达到或超过**100 Mb/s**的以太网称为**高速以太网**。 在双绞线上传送100 Mb/s基带信号的星型拓扑以太网,仍使用IEEE 802. 3的CSMA/CD协议。100BASE T以太网又称为**快速以太网**(Fast Ethernet) 。 **特点:** - 可在全双工方式下工作而无冲突发生。因此,不使用CSMA/CD 协议。MAC帧格式仍然是802.3标准规定的。 - 保持最短帧长不变,但将一个网段的最大电缆长度减小到100 m。帧间时间间隔从原来的9.6 μs改为现在的0. 96 μs。 ## 吉比特以太网 - 允许在1 Gb/s 下全双工和半双工两种方式工作。 - 使用802. 3协议规定的帧格式。 - 在半双工方式下使用CSMA/CD协议(全双工方式不需要使用CSMA/CD协议) - 与10BASE-T和100BASE- T技术向后兼容。 - 当吉比特以太网工作在全双工方式时(即通信双方可同时进行发送和接收数据),不使用载波延伸和分组突发。

加载全部内容

相关教程
猜你喜欢
用户评论