主机 H1 给主机 H2 发送数据,中间要经过 3 个路由器和电话网、局域网以及广域网等多种网络。从五层协议原理体系结构角度来看
为了专注数据链路层内容,这里我们只考虑数据链路层,而不考虑其他层
主机 H1 到 H2 的通信可以看作在 4 个不同链路上组成
链路
(LINK)就是从一个结点到相邻结点的一段物理线路,而中间没有任何其他的交换结点要在链路上传输数据,仅有链路还不够,还需要一些通信协议来控制数据的传输
数据链路
(Data Link)是指把实现通信协议的硬件和软件加到链路上,就构成了数据链路在数据链路层上传输的数据包又称为 帧
封装成帧
数据在应用层被封装成为应用层数据单元
运输层==>为其添加运输层协议首部(成为运输层协议数据单元)
网络层==>添加网络层协议首部(成为网络层协议数据单元)
数据链路层==>添加帧头帧尾(即封装成帧)
差错检测
检错码和检错算法对数据进行校验(如下图FCS)
这三个问题针对于点对点信道的数据链路层,使用广播信道的数据链路层除了这三个问题外,还有一些其他问题
封装成帧
是指数据链路层给上层交付的协议数据单元添加 帧头 和 帧尾 的过程帧头和帧尾中包含有重要的控制信息
帧头和帧尾的作用之一就是帧定界
发送方的数据链路层将上层交付下来的协议数据单元封装成帧后,还要通过物理层将构成帧的各比特转换成电信号发送到传输媒体。
如下图,红色字段为帧定界标志
并不是每一种数据链路层协议的帧都包含帧定界标志。例如,以太网 V2 的 MAC 帧:
透明传输是指数据链路层对上层交付的传输数据没有任何限制,就好像数据链路层不存在一样。
要实现透明传输就要思考一个问题,如果上层交付的协议数据单元中含有帧定界标志应该怎么办?
对此有两种解决方案:
在发送数据前,对帧的数据部分进行扫描,每出现一个帧定界符或转义字符,就在其前面插入一个转义字符。这里的转义字符是一个特殊的控制字符,长度为 1 个字节,十进制值为 27。
面向比特的物理链路使用 比特填充 的方法实现透明传输
在发送前对数据部分进行扫描每 5 个连续的比特 1 后面就插入 1 个比特 0,这样就确保了帧定界在整个帧中的唯一性,也就可以实现透明传输。接收方数据链路层将每5个连续比特 1 后比特 0 剔除即可。
考虑到差错控制等多种因素,每一种数据链路层协议都规定了帧的数据部分的长度上限,即 最大传送单元MTU (Maximum TransferUnit)
下面介绍两种检错方法:奇偶校验、循环冗余校验
这种检错方法漏检率比较高,计算机网络的数据链路层一般不会采用这种检测方法
具体步骤:
收发双方约定好一个 生成多项式 G(x)
发送方基于待发送的数据和生成多项式计算出差错检测码(冗余码),将其添加到待传输数据的后面一起传输
接收方通过生成多项式来计算收到的数据是否产生了误码
需要注意,CRC算法要求生成多项式必须包含最低次项
分析
注意:
使用差错检验技术,接收方的数据链路层就可检测出帧在传输过程中是否产生了误码(比特错误)。那么接下来如何处理呢?
这取决于数据链路层向其上层提供的服务类型:
对有线链路而言
对于无线链路
例如:TCP/IP四层体系结构中:
可靠传输的实现比较复杂,开销也比较大,是否使用可靠传输取决于应用需求
停止 - 等待协议SW
回退N帧协议GBN
选择重传协议SR
需要注意的是,这三种可靠传输实现机制的基本原理 可以应用到计算机网络体系结构的各层协议 中
示意图
停止等待的过程
传输过程出现的三个问题
两点说明:
为解决该问题,可采用 超时重传 实现数据分组的重新传输
为 避免重复分组 这种传输错误,必须给每个分组 带上序号。
对确认分组也进行编号,就可以使发送方避免这种误判
停止 - 等待协议的 信道利用率
如果发送发在收到接收方的确认分组之前,可以连续发送多个数据分组,则可大大提高信道利用率,这是一种流水线式的传输,如下图所示
为此,我们引入 回退 N 帧协议 GBN
在 流水线传输 的基础上利用 发送窗口 来限制发送方可连续发送数据分组的数量
在协议的工作过程中发送窗口和接收窗口不断向前滑动,因此这类协议又称为 滑动窗口协议
示例分析:
过程分析
累计确认:
接收方 不一定要对收到的数据分组逐个发送确认,而是可以在收到几个数据分组后(由具体实现决定),对按需到达的 最后一个数据分组发送确认
ACKn: 表示序号为 n 及以前的所有数据分组都已正确接收
当接收完 0 号和 1 号数据分组后,给发送方发送一个累积确认 ACK1,接受完 2~4 号分组后,发送累积确认ACK4。假设ACK1在传输过程中丢失,而ACK4正确到达发送方,发送方接收后就知道序号4及之前的分组都已正确接收。
错误时的情况
通过前文可知,一个数据分组的误码就会导致后续多个数据分组不能被接收方按序接收而丢弃(尽管它们无乱序和误码)。这必然会造成发送方对这些数据分组的超时重传,对通信资源产生极大浪费,因此引入选择重传协议。
概念
设法 只重传出现误码的数据分组。因此,接收窗口的尺寸WR不再等于 1 (而是 大于 1),以便 接收方先收下窗口内无误码的数据分组 ,等所缺部分收齐后一并递交上层,这就是 选择重传协议
示例分析:
传输条件:
但在传输过程中 2 号数据分组丢失
过程分析:
点对点协议 PPP(Point-to-Point Protocal)是目前使用最广泛的点对点数据链路层协议
另外,PPP协议也广泛用于广域网路由器之间的专用线路
PPP协议为在点对点链路传输各种协议数据报提供了一个标准方法,主要由以下三部分构成:
面向字节的异步链路
面向比特的同步链路
PPP帧尾部包含有 1 个两字节的帧检验序列 FCS 字段,使用循环冗余校验 CRC 来计算该字段的取值
生成多项式
接收方每收到一个PPP帧,就进行 CRC 检验。若 CRC 检验正确,就收下这个帧;反之,就丢弃这个帧。使用PPP的数据链路层 向上提供不可靠传输服务。
以拨号接入为例,简单介绍PPP协议的工作状态
共享信道要着重考虑的一个问题就是如何协调多个发送和接收站点对一个共享传输媒体的占用,即 媒体接入控制 MAC (Medium Access Control)
媒体接入控制主要分类
静态划分信道
动态接入控制
在 集中控制 的多点轮询协议中,有一个主站以循环方式 轮询 每个站点有无数据发送,只有被轮询到的站点才能发送数据。集中控制的最大缺点,就是存在单点故障问题 (已淘汰)
在 分散控制 的令牌传递协议中,各站点是平等的,并连接成一个环型网络。令牌(一种特殊的控制帧)沿环逐站传递,接收到令牌的站点才有权发送数据,并在发送完数据后,将令牌传给下一个站点(已淘汰)
采用 令牌协议 的典型网络有:IEEE 802.5 令牌环网,IEEE 802.4 令牌总线网,光线分布式数据接口FDDI(已淘汰)
随机接入 的特点是 所有站点通过竞争,随机的在信道上发送数据。如果有两个或以上站点在同一时刻发送数据,那么信号在共享媒体上就要 产生碰撞,使得站点的发送都失败。因此,这类协议要解决的关键问题是如何 避免冲突,以及发生冲突后如何 尽快恢复通信
著名的共享式以太网采用的就是 随机接入
随着技术的发展,交换技术的成熟和成本的降低,具有更高性能的使用点对点链路和链路层交换机的交换式局域网在有线领域已完全取代了共享式局域网,但由于无线信道的广播天性,无线局域网仍然使用的是共享技术
信道复用:
实际上,由于该技术主要用于多址接入,人们更常用的名词是 码分多址 CDMA
同理,频分复用 FDM 和时分复用 TDM 同样可用于多址接入,相应的名词是频分多址 FDMA 和时分多址 TDMA
这里,我们不严格区分复用和多址的概念。可简单理解如下:
与 FDM 和 TMD 不同,CMD 的每一个用户可以在 同样的时间使用同样的频带进行通信
由于 各用户使用经过特殊挑选的不同码型,因此用户之间 不会造成干扰
码片:
码片序列的挑选原则如下:
应用
早期的共享式以太网采用 载波监听多址接入/碰撞检测 ,即 CSMA/CD协议 来解决碰撞冲突问题
多址接入
载波监听CS
碰撞检测CD
每一个正在发送帧的站边发送边检测碰撞(边听边说):
一旦发现总线上出现碰撞,则立即停止发送,退避一段随机时间后再次发送
举例分析
假设在主机 B 发送帧的过程中,主机 C 也要发送帧。主机 C 进行载波监听,发现总线空闲 96 比特后立即发送帧,这必然导致碰撞
碰撞信号沿总线传播,主机 C 比主机 B 更早检测到碰撞并停止发送,退避一段随机时间后,重新发送之前所发送的帧
当主线 B 检测到碰撞后,同样也停止发送退避一段随机时间,重新发送之前所发送的帧
以太网还采用了一种 强化碰撞 的措施,这就是当发送帧的站点一旦检测到碰撞,除了立即停止发送帧外,还要继续 发送 32 比特或 48 比特的人为干扰信号(Jamming Signal),以便有足够多的碰撞信号使所有站点都能检测出碰撞。
CSMA/CD协议 —— 争用期(碰撞窗口)
CSMA/CD协议 —— 最小帧长
CSMA/CD协议 —— 最大帧长
示例
CSMA/CD协议 —— 截断二进制指数退避算法
CSMA/CD协议 —— 信道利用率
CSMA/CD协议 —— 帧发送流程
CSMA/CD协议 —— 帧接收流程
这种未能检测到信道上其他站点信号的问题叫做隐蔽站问题
IEEE 802.11是现今无线局域网通用的标准,虽然经常将 Wi-Fi 与 802.11 混为一谈,但两者并不等同
分布式协调功能DCF
:在DCF方式下,没有中心控制站点,每个站点使用CSMA/CA协议通过争用信道来获取发送权,这是802.11定义的默认方式点协调功能PCF
:CF方式使用集中控制的接入算法,是802.11定义的可选方式,实际中较少使用帧间隔符IFS:
CSMA/CA 协议工作原理
此处引出三个问题
源站为什么在检测到信道空闲后还要再等待一段时间 DIFS ?
目的站为什么正确接收数据帧后还要等待一段时间 SIFS 才能发送 ACK 帧呢?
信道由忙转为空闲且经过DIFS时间后,为什么还要退避一段随机时间才能使用信道?
退避算法的时机
CSMA/CA 协议的退避算法
在执行退避算法时,站点为退避计时器设置一个随机的退避时间:
CSMA/CA 协议的信道预约和虚拟载波监听
为了尽可能减少碰撞的概率和降低碰撞的影响,802.11 标准允许要发送数据的站点对信道进行预约
除源站和目的站以外的其他各站,在收到CTS帧(或数据帧)后就推迟接入到无线局域网中。这样就保证了源站和目的站之间的通信不会收到其他站的干扰
如果RTS帧发生碰撞,源站就收不到CTS帧,需执行退避算法重传RTS帧
由于RTS帧和CTS帧很短,发送碰撞的概率、碰撞产生的开销及本身的开销都很小。而对于一般的数据帧,其发送时延往往大于传播时延,碰撞的概率很大,且一旦发生碰撞而导致数据帧重发,则浪费很多时间,因此用很小的代价对信道进行预约往往是很值得的。802.11 标准规定了 3 种情况供用户选择:
除RTS帧和CTS帧会携带通信需要持续的时间,数据帧也能携带通信需要持续的时间,这称为802.11的 虚拟载波监听 机制
由于利用虚拟载波监听机制,站点只要监听到RTS帧、CTS帧或数据帧中的任何一个,就能知道信道被占用的持续时间,而不需要真正监听到信道上的信号,因此虚拟载波监听机制能减少隐蔽站带来的碰撞问题
当多个主机连接在同一个广播信道上,要想实现两个主机之间的通信,则每个主机都必须有一个唯一的标识,即一个数据链路层地址
在每个主机发送的帧中必须携带发送主机和接收主机的地址。由于这类地址是用于媒体接入控制 MAC(Media Access Control),因此这类地址被称为 MAC地址
MAC 地址一般被固化在网卡(网络适配器)的电可擦可编程只读存储器 EEPROM 中,因此 MAC 地址也被称为 硬件地址
每个网络适配器都有一个全球唯一的 MAC 地址。而交换机和路由器往往拥有更多的网络接口,所以会拥有更多的 MAC 地址。严格来说,MAC 地址是对网络上各接口的唯一标识,而不是对网络上各设备的唯一标识
IEEE 802 局域网的 MAC 地址格式
它由 48 个比特构成,每 8 个比特为一字节,从左右依次为第一到第六字节。这种地址标识符称为 扩展的唯一标识符 EUI,对于 48 比特的 MAC 地址,可称为 EUI - 48。
IEEE 802 局域网的 MAC 地址表示方法
每 4 个比特写成 1 个十六进制的字符,共 12 个字符,每两个字符分为一组。
IEEE 802 局域网的 MAC 地址类型
IEEE 802 局域网的 MAC 地址发送顺序
广播 MAC 地址作用举例说明
一个拥有三台主机的总线型以太网,各主机网卡上固化了全球单播 MAC 地址。假设,主机 B 要给主机 C 发送单播帧
多播 MAC 地址作用 举例说明
主机 A 要发送多播帧给给多播地址。将该多播地址的左起第一个字节写成 8 个比特,可以看到最低比特位是 1,这就表明该地址是多播地址。
假设主机 B、C、D 支持 MAC 多播,各用户给自己的主机配置的多播组列表如下:
快速判断mac地址是否为多播地址
需要注意:给主机配置多播组列表进行私有应用时,不得使用公有的标准多播地址
IP 地址是因特网上的主机和路由器所使用的地址,用于标识两部分信息:
很显然,之前介绍的 MAC 地址不具备区分不同网络的功能,而 IP 地址具备此种功能
网络体系结构中的ip地址和MAC地址
数据包转发过程中的IP与MAC的变化情况
假设主机 H1 要向主机 H2 发送数据包
过程
每一台主机都维护着一张ARP高速缓存表,用于记录ip地址与mac地址的对应关系
主机B发送数据包的时候,主机会在ARP高速缓存表中查询目的地址的mac地址,如果不存在,就发送ARP请求报文(局域网内广播)
其他主机收到广播之后会交付上层处理,上层的arp进程发现需要的不是自己的ip地址,会将其直接忽略,如果是自己的ip地址,则将B的IP地址与MAC地址记录到自己的ARP高速缓存表中,然后给B发送ARP响应,告知自己的mac地址
ARP缓存的类型:
动态
:自动获取,生命周期默认为两分钟;
静态
:手工设置,不同操作系统下的生命周期不同,例如系统重启后不存在或系统重启后依然有效。
使用集线器的以太网在逻辑上仍是一个总线网,各站共享总线资源,使用的还是CSMA/CD协议;
集线器只工作在物理层,它的每个接口仅简单地转发比特,不进行碰撞检测(由各站的网卡检测);
集线器一般都有少量的容错能力和网络管理功能。例如,若网络中某个网卡出了故障,不停地发送帧。此时,集线器可以检测到这个问题,在内部断开与出故障网卡的连线,使整个以太网仍然能正常工作。
使用集线器可以在物理层扩展以太网
以太网交换机通常都有多个接口。每个接口都可以直接与一台主机或另一个以太网交换机相连。一般都工作在全双工方式。
以太网交换机具有并行性,能同时连通多对接口,使多对主机能同时通信,无碰撞(不使用CSMA/CD协议)。
以太网交换机一般都具有多种速率的接口,例如:
10Mb/s、100Mb/s、1Gb/s、10Gb/s接口的多种组合。
以太网交换机工作在数据链路层(也包括物理层),它收到帧后,在帧交换表中查找帧的目的MAC地址所对应的接口号,然后通过该接口转发帧。
以太网交换机是一种即插即用设备,其内部的帧交换表是通过自学习算法自动地逐渐建立起来的。
帧的两种转发方式:
存储转发
直通交换:采用基于硬件的交叉矩阵(交换时延非常小,但不检查帧是否右差错)
单播帧对比
集线器:
与集线器链接的所有主机都会收到消息,然后对比目的地址,发现不是自己的地址就拒绝接收
交换机:
会查询自身的帧交换表发送给目的主机
广播对比
基本没有区别
扩展以太网:
发送单播帧
发送广播帧
碰撞比较
以太网交换机工作在数据链路层(也包括物理层)
以太网交换机收到帧后,在帧交换表中查找帧的目的MAC地址所对应的接口号,然后通过该接口转发帧。
以太网交换机是一种即插即用设备,刚上电启动时其内部的帧交换表是空的。随着网络中各主机间的通信,以太网交换机通过自学习算法自动逐渐建立起帧交换表。
如何提高以太网的可靠性?
添加冗余链路可以提高以太网的可靠性
但是,冗余链路也会带来负面效应——形成网络环路
网络环路会带来以下问题:
广播风暴
大量消耗网络资源,使得网络无法正常转发其他数据帧;
主机收到重复的广播帧
大量消耗主机资源
交换机的帧交换表震荡(漂移)
以太网交换机使用生成树协议STP(Spanning Tree Protocol),可以在增加冗余链路来提高网络可靠性的同时又避免网络环路带来的各种问题。
以太网交换机工作在数据链路层(也包括物理层)
使用一个或多个以太网交换机互连起来的交换式以太网,其所有站点都属于同一个广播域。
随着交换式以太网规模的扩大,广播域相应扩大。
巨大的广播域会带来很多弊端:
广播风暴
难以管理和维护
潜在的安全问题
网络中会频繁的出现广播信息
TCP/IP协议栈中的很多协议都会使用广播:
地址解析协议ARP
(已知IP地址,找出其相应的MAC地址)路由信息协议RIP
(一种小型的内部路由协议)动态主机配置协议DHCP
(用于自动配置IP地址)NetBEUI
:Widnows下使用的广播型协议
IPX/SPX
:Novell网络的协议栈
Apple Talk
:Apple公司的网络协议栈
如何分割广播域?
同一个vlan中的主机才能收到彼此之间的广播
IEE802.1Q
交换机的端口类型
交换机的端口类型有以下三种:
Access
Trunk
Hybrid
交换机各端口的缺省VLAN ID
Native VLAN
,即本征VLAN。Port VLAN ID
,即端口VLAN ID,简记为PVID。Access端口
Trunk端口
Hybrid端口