计网第五章——链路层
链路层
相关概念
- 结点:运行链路层协议的任何设备;
- 链路:沿着通信路径连接相邻结点的通信信道;
- 网络适配器(网络接口卡):位于它核心的是链路层控制器;
提供的服务
- 成帧:链路层把从网络层的数据封装成帧,一个帧由一个数据字段和若干首部字段组成,网络层数据报就插在数据字段中;
- 链路接入:MAC(媒体访问控制)协议规定了帧在链路上传输的规则;
- 点对点链路:单个发送方-单个接收方;
- 广播链路:单个发送方-很多接收方。会产生 多路访问问题,解决它们就出现了 多路访问协议。
- 可靠交付:当链路层协议提供可靠交付服务时,它保证无差错的经链路层移动每个网络层数据报,和应用层一样也是通过 确认 和 重传 取得的;
- 差错检测和纠正(EDC):若可以在本地对差错进行修正则没必要重传分组。
差错检测和纠正(EDC)
具体做法是在从网络层传递下来的数据字段D后面加上 EDC 字段,用来检测D是否出错。
奇偶校验
不多说,EDC只有一位,若要确定在哪个位置出现差错,可用二维奇偶校验。
检验和
假设帧有d bit长,将d分割成每份k bit。将这k bit加起来。取反码 作为EDC。
循环冗余检测(CRC)
详见本人另一篇博客:
多路访问协议
对于速率位R bps的广播信道,我们当然希望多路访问协议具有以下特性:
- 当仅有一个结点有数据发送时,该结点具有Rbps的吞吐量;
- 当有M个结点要发送数据时,每个结点吞吐量为 R/M bps(可以不是每时每刻,但平均要是这么多);
- 协议是分散的,不会因为某主节点故障而使整个系统崩溃;
- 协议的简单的,实现不昂贵。
信道划分协议
主要分为——TDM(时分多路复用)和FDM(频分多路复用):
- TDM:分别是在时间上共享广播信道,将时间划分为时间帧,并进一步划分每个时间帧为N个时隙,然后把每个时隙分配给N个结点中的一个;
- FDM:将R bps的信道划分为不同的频段,每个频段具有 R/N 带宽,并把每个牝鹿分配给N个结点中的一个。
但这两种方式都有相同的优点和缺点:
- 避免了碰撞,在N个结点之间公平地划分了带宽;
- 但限制一个结点只能使用 R/N 的带宽,这种情况当只有一个结点时显得尤为严重。
所以另外出现了一种方式——码分多址(CDMA),对每个结点分配一种不同的编码,类似于TDM中的时隙和FDM中的频率。
随机接入协议
在随机接入协议中,一个传输结点总是以信道的全部速率(即R bps)进行发送:
- 当有碰撞时,涉及碰撞的每个结点反复地重发它的帧,到该帧无碰撞地通过为止;
- 但是当一个结点经历一次碰撞时,他不必立刻重发该帧。相反,它在重发该帧前等待一个随机时延。涉及碰撞的每个结点独立地选择随机时延。
时隙ALOHA
其中,以概率p重传,是指某结点有效地投掷一个有偏倚的硬币,硬币正面时间对应着重传,而重传出现的概率为p。 硬币反面事件对应着“跳过这个时隙,在下个时隙再掷硬币”
最大效率
共有N个结点假设一个给定结点传输的概率是p,剩余结点不传输的概率是 (1-p)N-1。
因此,一个给定结点成功传送的概率是 p(1-p)N-1。
有N个结点,则任意一个结点成功传送的概率是 N* p(1-p)N-1
对上述得到的概率求个极限,得到 p=1/e=0.37 时有最大效率,也就是说,最多仅有 37% 的时隙同时在做有用的工作。
ALOHA
-
时隙ALOHA协议要求所有的结点同步他们的传输,以在每个时隙开始时开始传输;
-
而ALOHA协议是非时隙、完全分散的协议:
- 在纯ALOHA中,当一帧首次到达,结点立刻将该帧完整的传输进广播信道;
- 如果一个传输的帧在一个或多个传输经历了碰撞,这个结点将立即(在完全传输完它的碰撞帧后)以概率p传输该帧,或者以概率1-p在另一个帧时间等待。
和上面的计算过程一样,得到当 p=1/e 时有最大效率,为时隙ALOHA的一半。
载波侦听多路访问协议(CSMA)
- 载波侦听:一个结点在传输前先听信道,如果来自另一个结点的帧正向信道上发送,结点则等待直到检测到一小段时间没有传输,然后开始传输;
- 碰撞检测:当一个传输结点在传输时一直在侦听此信道,如果它检测到另一个结点正在传输干扰帧,则停止传输。
具有碰撞检测的载波侦听多路访问(CSMA/CD)
发生碰撞时使用二进制指数后退算法可使碰撞结点数量较少时,时间间隔较短,当碰撞结点数量较大时,时间间隔较长。
二进制指数后退算法是指当传输一个给定帧时,在该帧经历了一连串的n次碰撞后,结点随机地从中选择一个K值。因此,一个帧经历的碰撞越多,K的时间间隔越大。
CSMA/CD效率:当有大量结点,且每个结点有大量的帧要发送时,帧在信道中无碰撞地传输的那部分时间在长期运行时间中所占的份额。
-
dprop表示信号能量在任意两个适配器之间传播所需的最大时间;
-
dtrans表示传输一个最大长度的以太网帧的时间。
轮流协议
多路访问协议的两个理想特性是:
-
当只有一个结点活跃时,该结点具有R bps的吞吐量
-
当有M个结点活跃时,每个活跃结点的吞吐量接近R/M bps。
ALOHA和CSMA只满足第一个特性。而轮流协议能够满足两个特性。轮流协议中比较重要的两个协议是轮询协议和令牌传递协议。
轮询协议
要求这些结点之一要被指定为主结点。主结点以循环的方式轮询每个结点。特别是,主结点告诉每个结点能够传输的帧的最多数量。
轮询协议消除了困扰随机接入协议的碰撞和空时隙,这使得轮询取得的效率高得多。但是他也有一些缺点:
- 引入了轮询时延,即同时一个结点“它可以传输”所需的时间(只有一个结点时使得速率小于R bps);
- 如果主结点故障,整个信道都变得不可操作。
令牌传递协议
一个称为令牌的小的特殊帧在结点之间以某种固定的次序传递。当一个结点收到令牌时,仅当它有一些帧要发送时,他才持有这个令牌。否则,他立即向下一个结点转发该令牌。
令牌传递是分散的,并有很高的效率,但是他也有一些问题:
- 如果一个结点故障,则会导致整个信道崩溃;
- 如果一个结点偶然网际了释放令牌,则必须调用某些恢复步骤使令牌返回到循环中来。
链路层寻址与ARP
详见本人的另一篇博客:
以太网
以太网是第一个广泛部署的高速局域网。
大多以太网使用一种基于集线器的星型拓扑(从中间往四周发散)结构;
集线器
是一种物理层设备,它作用域各个比特而不是作用于帧,当接受到一个1或0比特的时候,集线器只是重新生成这个比特,并将其能量强度放大,并将该比特向其他所有接口传输出去。
位于中心的集线器是 交换机。
以太网帧结构
字段 | 含义 |
---|---|
前同步码 | 用来使接收端的适配器在接收 MAC 帧时能够迅速调整时钟频率,使它和发送端的频率相同。前同步码为 7 个字节,1 和 0 交替。 |
帧开始定界符 | 帧的起始符,为 1 个字节。前 6 位 1 和 0 交替,最后的两个连续的 1 表示告诉接收端适配器:“帧信息要来了,准备接收”。 |
目的地址 | 接收帧的网络适配器的物理地址(MAC 地址),为 6 个字节(48 比特)。作用是当网卡接收到一个数据帧时,首先会检查该帧的目的地址,是否与当前适配器的物理地址相同,如果相同,就会进一步处理;如果不同,则直接丢弃。 |
源地址 | 发送帧的网络适配器的物理地址(MAC 地址),为 6 个字节(48 比特)。 |
类型 | 上层协议的类型。由于上层协议众多,所以在处理数据的时候必须设置该字段,标识数据交付哪个协议处理。例如,字段为 0x0800 时,表示将数据交付给 IP 协议。 |
数据 | 也称为效载荷,表示交付给上层的数据。以太网帧数据长度最小为 46 字节,最大为 1500 字节。如果不足 46 字节时,会填充到最小长度。最大值也叫最大传输单元(MTU)。 在 Linux 中,使用 ifconfig 命令可以查看该值,通常为 1500。 |
帧检验序列 FCS | 检测该帧是否出现差错,占 4 个字节(32 比特)。发送方计算帧的循环冗余码校验(CRC)值,把这个值写到帧里。接收方计算机重新计算 CRC,与 FCS 字段的值进行比较。如果两个值不相同,则表示传输过程中发生了数据丢失或改变。这时,就需要重新传输这一帧。 |
特点
-
以太网向网络层提供无连接服务,即不需要握手;
-
以太网向网络层提供不可靠服务,当接收方收到来自发送方的帧时,会执行CRC校验,但不发送ACK和NAK,若发现错误就进行简单丢弃,丢弃的话 数据就会形成间隙:
- TCP,接收方的TCP将不会确认包含在丢弃帧中的数据,引起发送方的重发,但接收方再次收到数据时不知道是重传还是新发的;
- UDP,接收方会将数据上传,但发送方不会知道。
-
以太网 既是 链路层 又是 物理层 的规范;
链路层交换机
作用
- 过滤:决定一个帧应该转发到某个接口,还是应当将其丢弃;
- 转发:决定一个帧应该被导向哪个接口。
交换机表
假定目的为 DD-DD-DD-DD-DD-DD 的帧从交换机接口x到达,交换机用MAC地址 DD-DD-DD-DD-DD-DD 索引它的表,有3种可能的情况:
- 表中没有对应MAC的这一项,交换机向除了x接口外的所有接口前面的输出缓存转发该帧的副本,也就是说,没有没有对于目的地址的表项,交换机广播该帧;
- 有一个表项和MAC地址对应,但接口就是来的接口x,则执行过滤功能;
- 有一个表现和MAC地址对应,接口不是x,该帧被转发到接口y前面的输出缓存。
自学习
- 交换机表初始为空;
- 对于每个接口接收到的每个入帧,交换机在其表中存储:
- 在该帧源地址字段种的MAC地址;
- 该帧到达的接口;
- 当前时间。
- 如果一段时间(称为老化期)后,交换机没有接收到以该地址作为源地址的帧,就在表中删除这个地址。
交换机和路由器比较
路由器和链路层交换机都是 存储转发分组交换机,但有许多不同:
- 交换机是第二层(链路层)的分组交换机,路由器是第三层(网络层)的分组交换机;
- 交换机是即插即用的 即无需网络管理员配置它的表项 (自学习)。路由器则不是,表项需要路由选择算法来配置;
- 交换机中,一个大型交换网络将要求在主机和路由器中有大的ARP表,这将生成客观的ARP流量和处理量,且交换机对于广播风暴并不提供任何保护措施。
那什么时候用哪种呢?
小网络——交换机,因为它们不要求IP地址的任何配置就能使流量局部化并增加总计吞吐量;
大网络——通常在网络中除了交换机之外,还包括路由器。因为路由器提供了更健壮的流量隔离方式和对广播风暴的控制,并在网络主机之间使用更“智能的”路由。
多协议标签交换(MLPS)
传统的路由网络里面,当一个(无状态的)网络层协议数据包(例如IP协议报文)在路由器之间游荡时,每个路由器都是独立的对这个数据包做出路由决策。路由决策就是路由器决定数据包如何路由转发的过程。
路由决策可以认为是由两部分组成:
- 分类,将特定的数据包归属为一个等价转发类(Forwarding Equivalence Classes,FECs)
- 查找,查找FEC对应的next hop
而MPLS提出:
- 当网络数据包进入MPLS网络时,对网络数据包进行解包,计算归属的FEC,生成标签(Label);
- 当网络数据包在MPLS网络中传输时,MPLS使能的路由器不需要提取目的IP地址和在转 发表中执行最长前缀匹配的查找;
- Label是个整数,以整数作为key,可以达到O(1)的查找时间。大大减少了路由决策的时间。这里的Label就是MPLS里面的L;
- 需要注意的是Label在MPLS网络里面,是作为网络数据包的一部分,随着网络数据包传输的。
MPLS的核心就是,一旦进入了MPLS网络,那么网络数据包的内容就不再重要,路由决策(包括FEC归属的计算,next hop的查找)都是基于Label来进行的。
MPLS首部中的字段:
- 标签Label;
- 预留的3比特实验字段;
- 1比特S字段,用 于指示一系列“成栈”的MPLS首部的结束(我们这里不讨论这个高级主题);
- 寿命字段。
注意事项
-
一个MPLS加强的帧仅能在两个均为MPLS使能的路由器之 间发送。(因为一个非MPLS使能的路由器,当它在期望发现IP首部的地方发现了一个 MPLS首部时会相当混淆!);
-
一个MPLS使能的路由器常被称为标签交换路由器(label switched router),因为它通过在其转发表中查找MPLS标签,然后立即将数据报传递给适当的输岀接口来转发MPLS帧;
-
因此,MPLS使能的路由器不需要提取目的IP地址和在转发表中执行最长前缀匹配的查找。
优点
- MPLS基于标签执行交换, 而不必考虑分组的IP地址,交换速度加快;
- IP路由选择协议将只指定到A的单一最小费用的路径。MPLS提供了沿着多条路由转发分 组的能力,这是是使用MPLS的一种简单 形式的流量工程;
- 能用于执行MPLS转发路径的快速恢复;
- 能够并且已经被用于实现所谓虚拟专用网。
数据中心网络
每个数据中心都有自己的数据中心网络,这些数据中心网络将其内部主机彼此互联 并与因特网中的数据中心互联。
数据中心中的数据被称为刀片(blade),主机被堆叠在机架上,每个机架一般对方20~40台刀片,机架顶部的那台交换机被称为 机架顶部(TOR)交换机,它们于机架上的主机互联,并与数据中心中的其他交换机互联。
数据中心网络支持两种类型的流量:
- 外部客户与内部主机之间流动的流量;
- 内部主机之间流动的流量。
为了处理第一种流量,数据中心网络包括了一台或多台 边界路由器,它们将数据中心网络与公共因特网相连。