计算机网络数据链路层之使用广播信道的数据链路层(含MAC帧格式)
局域网的数据链路层
-
局域网最主要的特点是:
- 网络为一个单位所拥有;
- 地理范围和站点数目均有限。
-
局域网具有如下主要优点:
- 具有广播功能,从一个站点可很方便地访问全网,局域网上的主机可共享连接在局域网上的各种硬件和软件资源。
- 便于系统扩展和逐渐地演变,各设备的位置可灵活调整和改变。
- 提高了系统的可靠性、可用性和残存性。
局域网拓扑结构
局域网传输媒体
共享信道带来的问题
- 使用一对多的广播通信方式。
- 问题:若多个设备在共享的广播信道上同时发送数据,则会造成彼此干扰,导致发送失败。
媒体共享技术
- 静态划分信道
- 频分复用
- 时分复用
- 码分复用
- 波分复用
- 动态媒体接入控制(多点接入)
- 随机接入
- 受控接入,如多点线路探询(polling),或轮询。
1.以太网的两个标准
- DIX Ethernet V2是世界上第一个局域网产品(以太网)的规约。
- IEEE 802.3是第一个IEEE的以太网标准。
- DIX Ethernet V2标准与IEEE的802.3标准只有很小的差别,因此可以将802.3局域网简为“以太网”。
- 严格说来,“以太网”应当是指符合DIX Ethernet V2标准的局域网。
数据链路层的两个子层
- 为了是数据链路层能够更多地适应多种局域网标准,IEEE 802 委员会就将局域网的数据链路层拆成两个子层:
- 逻辑链路控制LLC(logical link control)子层;
- 媒体接入控制MAC(medium access control)子层。
- 与接入到传输媒体有关的的内容都放在MAC子层,而LLC子层则与传输媒体无关。
- 不管采用何种协议的局域网,对LLC子层来说都是透明的。
局域网对LLC子层是透明的
一般不考虑LLC子层
- 由于TCP/IP体系经常使用的局域网上是DIX Ethernet V2而不是802.3标准中的几种局域网,因此现在802委员会定制的逻辑链路控制子层LLC(即802.2标准)的作用已经不大了。
- 很多厂商生产的适配器上就仅装有MAC协议而没有LLC协议。
2.适配器的作用
- 网络接口板又称为通信适配器(adapter)或网络接口卡NIC(network interface card),或“网卡”。
- 适配器的重要功能:
- 进行串行/并行转换。
- 对数据进行缓存。
- 在计算机的操作系统安装设备驱动程序。
- 实现以太网协议。
计算机通过适配器和局域网进行通信
CSMA/CD协议
-
最初的以太网是将许多计算机都连接到一根总线上。易于实现广播通信。当初认为这样的连接方法既简单有可靠,因为总线上没有源器件。
-
为了实现一对一通信,将接收站的硬件写入帧首部中的目的地址字段中。仅当数据帧中的目的地址与适配器的硬件地址一致时,才能接收这个数据帧。
-
总线也有缺点。若多台计算机或多个站点同时发送时,会产生发送碰撞或冲突,导致发送失败。
以太网采用了两种重要的措施
为了通信的简便,以太网采用了两种重要的措施。
(1)采用较为灵活的无连接的工作方式
- 不必先建立连接就可以直接发送数据。
- 对发送的数据帧不进行编号,也不要求对方发回确认。
- 这样做的理由是局域网信道的质量很好,因信道质量产生差错的概率是很小的。
以太网提供的服务
- 以太网提供的服务是不可靠的交付,即尽最大努力的交付。
- 当目的站收到有差错的数据帧时就丢弃此帧,其它什么也不做。差错的纠正由高层来决定。
- 如果高层发现丢失了一些数据而进行重传,但以太网并不知道这是一个重传的帧,而是当作一个新的数据帧来发送。
如何避免同时发送产生的碰撞?采用CSMA/CD
(2)以太网发送的胡数据都使用曼彻斯特(manchester)编码
曼彻斯特编码缺点是:它锁帧的频带宽度比原始的基带信号增加了一倍。
以太网提供的服务
- CSMA/CD含义:载波监听多点接入/碰撞检测(carrier sense multiple access with collision detection)。
- “多点接入”表示许多计算机以多点接入的方式连接在一根总线上。
- “载波监听”是指每一个站在发送数据之前先要检测一下总线上是否有其它计算机在发送数据,如果有,则暂时不要发送数据,以免发生碰撞。
- 总线上并没有“载波”。因此,“载波监听”就是用电子技术检测总线上有没有其他计算机发送的数据信号。
碰撞检测
- “碰撞检测”就是计算机边发送数据边检测信道上的信号电压大小。
- 当几个站同时在总线上发送数据时,总线上的信号电压摆动值将会增大(互相叠加)。
- 当一个站检测到的信号电压摆动值超过一定门限值时,就认为总线上至少有两个站在同时在发送数据,表明产生了碰撞。
- 所谓“碰撞”就是发生了冲突。因此“碰撞检测“也称为”冲突检测“。
检测到碰撞后
- 在发生碰撞时,总线上传输的信号产生了严重的失真,无法从中恢复出有用的信息。
- 每一个正在发送数据的站,一旦发现总线上出现了碰撞,就要立即停止发送,免得继续浪费网络资源,然后等待一段随机时间后再次发送。
CSMA/CD协议工作流程
为什么发要进行碰撞检测?因为信号传播时延对载波监听产生了影响
A需要单程传播时延的2倍的时间,才能检测到与B的发送产生了冲突。
争用期
- 最先发送数据帧的站,在发送数据帧后至多经过时间**2t(两倍的端到端往返时延)**就可知道发送的数据帧是否遭受了碰撞。
- 以太网发的端到端往返时延2t称为争用期,或碰撞窗口。
- 经过争用期这段时间还没有检测到碰撞,才能肯定这次发送不会发生碰撞。
二进制指数类型退避算法(truncated binary exponential type)
-
发生碰撞的站在停止发送数据后,要推迟(退避)一个随机时间才能再发送数据。
-
基本退避时间取为争用期2t。
-
从整数集合[0,1,…,(2^k - 1)]中随机地取出一个数,记为r。重传所需的时延就是r倍的基本退避时间。
-
参数k按下面的公式计算:
k = M i n [ 重 传 次 数 , 10 ] k = Min[重传次数,10] k=Min[重传次数,10] -
k <= 10时,参数k等于重传次数。
-
当重传达16次仍不能成功时即丢弃该帧,并向高层报告。
-
-
例如:
-
第一次冲突重传时:
k = 1,r为{0,1}集合中的任何一个数。
-
第2次冲突重传时:
k = 2,r为{0,1,2,3}集合中任何一个数。
-
第3次冲突重传时:
k = 3,r为{0,1,2,3,4,5,6,7}集合中的任何一个数。
-
10Mbit/s以太网争用期的长度
-
10Mbit/s以太网取51.2us为争用期的长度。
-
对于10Mbit/s以太网,在争用期内可发送512bit,即64个字节。
这就意味着:
以太网在发送数据时,若前64字节没有发生冲突,则后续的数据就不会发生冲突。
最短有效帧长
- 如果发生冲突,就一定是在发送的前64字节之内。
- 由于一检测到冲突就立即终止发送,这时已经发送出去的数据一定小于64字节。
- 以太网规定了最短有效帧长为64个字节,凡长度小于64个字节的帧都是由于冲突而异常终止的无效帧。
覆盖范围
- 在10Mbit/s以太网51.2us的争用期内,信号能传输多远的距离?
- 以太网上最大的端到端单程时延必须小于争用期的一半(即25.6us),这相当于以太网的最大端到端的长度约为5km。
人为干扰信号
注意:B也能够检测到冲突,并立即通知发送数据帧,接着就发送干扰信号。这里为了简单起见,只会出A发送干扰信号的情况。
CSMA/CD协议的重要特性
- 使用CSMA/CD协议的以太网不能进行全双工通信而只能进行双向交替通信(半双工通信)。
- 每个站在发送数据之后的一小段时间内,存在这遭遇碰撞的可能性。
- 这种发送的不确定性是整个以太网的平均通信量远小于以太网的最高数据率。
CSMA/CD协议的要点
TIPS:mac帧之间的最小间隔是9.6us,而以太网是10Mbit/s,即至少得等待96bit的时间。
使用集线器的星形拓扑
-
传统以太网最初是使用粗同轴电缆,后来演进到使用比较便宜的细同轴电缆,最后发展为使用更便宜和更灵活的双绞线。
-
采用双绞线的以太网采用星形拓扑,在星形的中心则增加了发一种可靠性非常高的设备,叫做集线器(hub)。
传统以太网使用同轴电缆,采用总线形拓扑结构
使用集线器的双绞线以太网
星形以太网10BASE-T
- 使用无屏蔽双绞线,采用星形拓扑。
- 每个站需要用两对,分别发用于发送和接收。
- 双绞线的两端使用RJ-45插头。
- 集线器使用了大规模集成电路芯片,因此集线器的可靠性提高。
- 10BASE-T的通信距离稍短,每个站到集线器的距离不超过100m。
10BASE-T以太网在局域网中的统治地位
- 这种10Mbit/s速率的无屏蔽双绞线星形网的出现,即降低了成本,又提高了可靠性。具有很高的性价比。
- 10BASE-T双绞线以太网的出现,是局域网发展史上的一个非常重要的里程碑,它为以外网在局域网中的统治地位奠定了牢固的基础。
- 从此以太网的拓扑就从总线型变为更加方便的星形网络,而以太网也就在局域网中占据了统治地位。
集线器的一些特点
- 集线器是使用电子器件来模拟实际电缆的工作,因此整个系统仍然像一个传统的以太网那那样运行。
- 使用集线器的以太网在逻辑上仍是一个总线网,各工作站使用的还是CSMA/CD协议,并共享逻辑上的总线。
- 集线器跟像一个多接口的转发器,工作在物理层。
- 集线器采用了专门的芯片,进行自适应串音回波抵消,减少了近端串音。
具有三个接口的集线器
以太网的信道利用率
- 多个站点在以太网上同时工作就可能发生碰撞。
- 当发生碰撞时,信道资源实际上是被浪费了。因此,当扣除碰撞所造成的信道损失后,以太网总的信道利用率并不能达到100%。
- 假设r是以太网单程端到端传播时延。则争用期长度为2r,即端到端传播时延的两倍。检测到碰撞后不发送干扰信号。
- 设帧长为L(bit),数据发送速率为C(bit/s),则帧的发送时间为T0 = L/C(s)。
以太网信道被占用的情况
-
一个站在发送帧时出现了碰撞。经过一个争用期2r后,可能又出现了碰撞。这样经过若干个争用期后,一个站发送成功了。假定发送帧需要的时间是T0。
-
注意到,成功发送一个帧需要占用信道的时间是T0 + r,比这个帧的发送时间要多一个单程端到端时延r。
-
这是因为当一个站发送完最后一个比特时,这个比特还要在以太网上传播。
参数a与利用率
-
要提高以太网的信道利用率,就必须减小r与T0之比。
-
在以太网中定义了参数a,它是以太网单程端到端时延r与帧的发送时间T0之比:
a = r / T 0 a = r/T_0 a=r/T0a -> 0,表示一发生碰撞就立即可以检测出来,并立即停止发送,因而信道利用率很高。
a越大,表明争用期所占用的比例增大,每发生一次碰撞就浪费许多信道资源,使得信道利用率明显降低。
对以太网参数a的要求
- 为提高利用率,以太网的参数a的值应当尽可能小些。
- 对以太网参数a的要求是:
- 当数据率一定时,以太网的连线的长度受到限制,否则r的数值会太大。
- 以太网的真长不能太短,否则T0的值会太小,使a值太大。
信道利用率的最大值Smax
-
在理想化的情况下,以太网上的各种发送数据都不会产生碰撞(这显然已经不是CSMA/CD,而是需要使用一种特殊的调度算法),即总线一旦空闲就有某一个站立即发送数据。
-
发送一帧占用线路的时间是T0+r,而帧本身的发送时间是T0。于是,我们可计算出理想情况下的极限信道利用率Smax为:
S m a x = T 0 T 0 + r = 1 1 + a S_{max} = \frac{T_0}{T_0+r} = \frac{1}{1+a} Smax=T0+rT0=1+a11、只有当参数a远小于1才能得到尽可能高的极限信道利用率。
2、据统计,当以太网的利用率达到30%时就已经处于重载的情况。很多的网络容量被网上的碰撞消耗掉了。
以太网的MAC层
重点介绍:
- 1.MAC层的硬件地址
- 2.MAC帧的格式
1.MAC层的硬件地址
- 在局域网中,硬件地址又称为物理地址,或MAC地址。
- 802标准所说的“地址“严格地讲应当是每一个站的”名字“或标识符。
- 但鉴于大家都早已习惯了将这种48位的”名字“称为”地址“,所以以下均使用这种习惯用法,尽管这种说法并不严格。
请注意,如果连接在局域网上的主机或路由器安装有多个适配器,那么这样的主机或路由器就有多个”地址“。更准确地说,这种48位”地址“应当是某个接口的标识符。
48位MAC地址
-
IEEE 802标准规定MAC地址字段可采用6字节(48位)或2字节(16位)这两种中的一种。
-
IEEE的注册管理机构RA负责向厂家分配地址字段6个字节中的前三个字节(即高位24位),称为组织唯一标识符。
-
地址字段6个字节中的后三个字节(即低位24位)由厂家自行指派,称为扩展唯一标识符,必须保证生产出的适配器没有重复地址。
-
一个地址块可以生成2^24个不同的地址。这种48位地址称为MAC-48,它的通用名称是EUI-48。
-
生产适配器时,6字节的MAC地址已被固化在适配器的ROM,因此,MAC地址也叫做硬件地址(hardware address)或物理地址。
-
”MAC地址“实际上就是适配器地址或适配器标识符EUI-48。
单站地址,组地址,广播地址
- IEEE规定地址字段的第一字节的最低位为I/G位。I/G表示individual/group。
- 当I/G位 = 0时,地址字段表示一个单站地址。
- 当I/G位 = 1时,表示组地址,用来进行多播(以前曾译为组播)。此时,IEEE只分配地址字段前三个字节中的23位。
- 当I/G位分别为0和1时,一个地址块可分别生成223个单个站地址和223个组地址。
- 所有48位都为1时,为广播地址。只能作为目的地址使用。
TIPS:
源地址:源IP地址,发送请求主机的IP地址。
目的地址:目的IP地址,被请求的主机IP地址。
当主机号全为1时,代表的是该网段的所有主机,像广播地址发送数据也就是跟同一个网段的所有主机发送数据。即广播地址可以作为目的地址。
如果广播地址作为源地址,它本身代表的是所有主机,那么目的地址是无法明确的,无法确定其目的地址是哪里。
全球管理与本地管理
- IEEE把地址字段第一个字节的最低第2位规定为G/L位,表示Global/Local。
- 当G/L位 = 0时,是全球管理(保证在全球没有相同的地址),厂商向IEEE购买的OUI都属于全球管理。
- 当G/L位 = 1时,是本地管理,这时用户可任意分配网络上的地址。
适配器检查MAC地址
- 适配器从网络上每收到一个MAC帧就首先用硬件检查MAC帧中的MAC地址。
- 如果是发往本站的帧则收下,然后再进行其它的处理。
- 否则就将此帧丢弃,不再进行其它的处理。
- “发往本站的帧”包括以下三种帧:
- 单播(unicast)帧(一对一)
- 广播(broadcast)帧(一堆全体)
- 多播(multicast)帧(一对多)
- 所有的适配器都至少能够识别前两种帧,即能够识别单播地址和广播地址。
- 有的适配器可用编程方法识别多播地址。
- 只有目的地址才能使用广播地址和多播地址。
- 以混杂方式(promiscuous mode)工作的以太网适配器只要“听到”有帧在以太网上传输就都能接收下来。
2.MAC帧的格式
- 常用的以太网MAC帧格式有两种标准:
- DIX Ethernet V2标准
- IEEE的802.3标准
- 最常用的MAC帧是以太网V2的格式
以太网V2的MAC帧格式
无效的MAC帧
- 数据字段的长度与长度字段的值不一致;
- 帧的长度不是整数个字节;
- 用收到的帧检验序列FCS查出有差错;
- 数据字段的长度不在发46~1500字节之间。
- 有效的MAC帧长度为64~1518字节之间。
对于检查出的无效MAC帧就简单地丢弃。以太网不负责重传丢弃的帧。
IEEE 802.3 MAC帧格式
与以太网V2 MAC帧格式相似,区别在于:
- IEEE 802.3规定的MAC帧的第三个字段是“长度/类型”。
- 当这个字段值大于0x0600时(相当于十进制的1536),就表示“类型”。这样的帧和以太网V2 MAC帧完全一样。
- 当这个字段值小于0x0600时才表示“长度”。
- 当“长度/类型”字段值小于0x0600时,数据字段必须装入上面的逻辑链路控制LLC子层的LLC帧。
现在市场上流行的都是以太网V2的MAC帧,但大家也常常把它称为IEEE 802.3标准的MAC帧。
帧间最小间隔
- 帧间最小间隔为9.6us,相当于96bit的发送时间。
- 一个站在检测到总线开始空闲后,还要等待9.6us才能再次发送数据。
- 这样做是为了使刚刚收到的数据帧的站的接收缓存来得及清理,做好接受下一帧的准备。