MPLS基础一(上)

在上图中,关于PC-A和PC-B之间互相访问的过程中

1、所有三层网络设备形成源和目的的路由条目

2、PC-A发出报文,source-IP为A,destination-IP为B

3、R1收到报文后,根据目的IP检查自己的路由表,查询得到出接口,将数据包从出接口发出

4、R2、R3同样如此,一直讲数据包传递到PC-B

5、PC-B做出回包,沿反方向传回数据

其中省略了二层mac地址的ARP查询和重写数据帧的内容

简而言之:IP数据报文在传递的过程中,根据目的IP地址,查询路由表,得到出接口将数据发出,源目的IP地址保持不变,mac地址逐跳改写

上面这个是我们耳熟能详的IP转发原理

其中我们为了方便理解,隐藏了其在转发过程中真实的一幕,即路由器收到IP报文时,查询的其实并不是路由表(RIB),而是转发表(LIB)

我们需要复习一下在NP交换部分所讲过的交换工作原理

最早期,交换机在交换数据帧时采用的交换方式我们称之为进程交换,所有的报文在交换时都需要经过CPU查询处理,导致交换效率一直无法提升

随后,新一代交换方式出现,即采用数据流的交换方式,我们将源目的IP、源目的mac、源目的端口及入接口都相同的流量称为同一个数据流,交换机在处理这些数据时,只需要对第一个报文使用CPU进行查询,后续的所有报文全都按照第一个报文的交换方式进行处理,大大提高了交换效率

而cisco根据数据流交换方式推出了自己独有的交换方式,在进程交换中,存在一个问题,即只有有流量触发后才会产生出对应的交换缓存,如果是处理大量不同数据流时,其实交换效率和进程交换一样慢;为了解决这个问题,cisco将其优化改进,利用交换机的闲时资源,提前计算出可能会收到的数据流的转发信息,将其载入缓存,当收到数据流时,直接使用预先缓存的转发信息处理报文,实现了正真的基于硬件的交换方式,cisco把这种方式成为思科特快转发(CEF)

正是由于CEF的高效,cisco在新的路由产品中也移植了这个功能,所以现在大家所能接触到的思科设备都具备CEF功能

而我们所谓的转发表其实就是CEF表,CEF表示根据路由表产生的,其不像路由表有大量的递归内容,CEF表中显示的就是一个数据包如果匹配中其下一步应该从哪个接口发出,简单高效

比如下面的这个路由表(RIB):

路由就会出现需要递归查询的情况

而我们去看一下CEF表(FIB)

路由器在闲时会根据路由表的信息,提前计算好转发信息,收到去往4.4.4.4的数据包直接从出接口F0/0发出

这张表我们就叫做FIB:转发信息库

而FIB是根据路由表产生的,路由表我们称为RIB:路由信息库

设备在收到IP报文时,其查询的其实是FIB并不是RIB,如果将CEF功能关闭,这是才会查询RIB即路由表

以上是我们在NA、NP中所学的IP转发原理的内容,做一些补充

下面,我们开始揭开MPLS的神秘面纱,来看一看内里乾坤

MPLS(Multiprotocol Label Switch)最初是用来提高路由器的转发速度而提出的一个协议,但随着技术发展,设备转发性能越来越强,其加快转发速度的优势逐渐弱化,而多层MPLS报头嵌套的设计成为了其最出彩的地方

目前用得比较多的场景主要是解决BGP路由黑洞问题和MPLS VPN数据转发

首先,我们需要对MPLS有个大概的认识,MPLS在传递报文时会在二层帧头和三层报头中间插入MPLS报头,所以很多人叫它2.5层

他的报文结构比IP报头简单得多,也小地多,只有4个字节(32bits)

结构如下:

前20位位标签位,用于表示当前的标签

EXP协议中未作定义,一般用作COS

S为栈底位,用于表示该MPLS报头是否为最后一个MPLS报头

TTL相信不用解释了

如此简单的接口我相信你看过一次就能记住,同样,设备在处理MPLS报文时也会比IP报文处理效率更高

在MPLS中有一些专业术语必须要了解

FEC:

Forwarding Equivalence Class,FEC(转发等价类),是在转发过程中以等价的方式处理的一组数据分组。

可以通过地址、隧道、COS等来标识创建FEC,

目前看到的MPLS中只是一条路由对应一个FEC。通常在一台设备上,对一个FEC分配相同的标签。

标签(Label)

是一个比较短的,定长的,通常只具有局部意义的标识(类似mac地址),这些标签通常位于数据链路层的数据链路层封装头和三层数据包之间,标签通过绑定过程同FEC相映射,即一个FEC对应一个标签。

LSP:

标签交换通道。一个FEC的数据流,在不同的节点被赋予确定的标签,数据转发按照这些标签进行。数据流所走的路径就是LSP。

LSR:

Label Switching Router,LSR是MPLS的网络的核心交换机,它提供标签交换和标签分发功能。

LER:

Label Switching Edge Router,在MPLS的网络边缘,进入到MPLS网络的流量由LER分为不同的FEC,并为这些FEC请求相应的标签。它提供流量分类和标签的映射、标签的移除功能。

了解了上面这些专业术语,那么我们研究一下数据是如何通过MPLS进行传递的,和IP之间有什么区别:

在上图中,我们需要解决几个问题:

标签是怎么产生的?

IP报文是怎么变成MPLS报文的?

报文是如何从源传递到目的的?

标签是怎么产生的?

为每一条路由产生一个唯一标签(local标签,也叫 in标签)

将这些标签传递给MPLS的邻居(remote标签,也叫out标签)

IP报文是怎么变成MPLS报文的?

在LER上,压入标签(根据IP报文的目的IP地址所对应的路由的标签)

报文是如何从源传递到目的的?

A发出IP报文,R1收到后查询FIB,得知需要压入标签

R1将报文转发给R2,R2收到MPLS报文,查询LFIB表中in标签,将原有的标签替换成现在这个in标签对应的out标签值

到达R3后,查询in标签,发现对应out标签为pop,则弹出最顶层标签,还原成IP报文,转发给R4

R4收到IP报文后,查询FIB表,将报文转发给B

其中涉及到几个动作:

push压入:为报文添加MPLS报头

swap替换:根据in标签查询的结果,将标签替换成out标签的值

pop 弹出:将最顶层的MPLS报头移除

untag 弹出:将所有MPLS报头都移除

PHP机制:倒数第二跳弹出,减少最后一条设备的查表次数

如果没有倒数第二跳弹出机制,在最后一条设备上才弹出标签,则在最后一条设备上首先需要查询LFIB表,得知需要弹出标签,弹出标签后变成IP报文,需要再次查询FIB表,共需要查询2次,而在倒数第二跳设备上弹出,变成IP报文后,最后一条设备就只需查询FIB表即可,只查一次

时间: 2024-10-11 01:07:22

MPLS基础一(上)的相关文章

MPLS基础一

多协议标签交换(MPLS) 是一种用于快速数据包交换和路由的体系,具有管理各种不同形式通信流的机制. 内容:RID     /     MTU     /      认证    /     TTL   /     非直连邻居    /     标签出入控制    /  同步 FIB表: LFIB表: LDP: LSR: PHP: 标签值3是RFC规定的隐式标签,思科上是标签1 同步:(IGP和LDP都同时认为某条链路是某个前缀的出接口时才把报文转发出去.) MPLS网络中,LDP和IGP不能同步

MPLS基础二(MPLS VPN)

基本配置思路: (MPLS VPN //PE与CE设备IGP RIP/OSPF) 1.在ISP内部运行IGP,然后运行MPLS LDP. 2.在PE上创建VRF,把PE与CE连接的接口划分进VRF. 3.在ISP中的运行MP-iBGP,即关闭BGP IPV4的默认单播能力,然后激活VPNV4邻居. 4.在PE设备上运行与CE相同的IGP,此IGP要在VRF中运行, 即( OSPF: router ospf 100 vrf A 或在vrf 接口中运行 ip ospf 100 area 0 RIP:

shell基础(上)

Shell基础(上) 1.1什么是shell Shell是一个命令解释器,它在操作系统的最外层,负责直接与用户对话,把用户的 输入解释给操作系统.井处理各种各样的操作系统的输出结果,输出屏幕返回给用户 这种对话方式可以是 交互的方式:从键盘输入命令,通过/bin/bash的解折,可以立即得到shell的回应 非交互的方式:脚本 Shell执行命令分为两种方式 内置命令:如讲过的cd ,pwd, exit和echo等命令.当用户登录系统后,shell以及内置命令就被系统载入到内存,并且一直运行 一

nodejs学习笔记_nodejs和PHP在基础架构上的差别--共享状态的并发

绝大多数对于Node.js的讨论都把关注点放在了处理高并发能力上,做开发的时候一定要明确node内部做出的权衡,以及node应用性能好的原因. node 为javascript引入了一个复杂的概念,:共享状态的并发. node採用一个长期执行的进程 而php在apache中会产生多个进程 例如以下图所看到的: 代码验证: PHP: <?php $i = 0; $i++; echo $i nodejs: var http = require('http'); var i=0; http.creat

前端开发工程师 - 03.DOM编程艺术 - 第1章.基础篇(上)

第1章.基础篇(上) DOM (Document Object Model) - 文档对象模型 以对象的方式来表示对应的html,它有一系列的规范 i.e. 在浏览器中,DOM是通过JS实现的. DOM: DOM Core:核心结构.API的定义 DOM HTML: 定义HTML如何转化成对象(HTML对应的对象)-- 操作节点 DOM Style:样式转换成对象 -- 操作样式 DOM Event:事件对象的模型 -- 响应用户的操作 文档树 HTML -> DOM树 节点遍历 node.pa

从零开始学Python第一周:Python基础(上)

Python语法基础(上) 一,Python的变量 (1)创建变量 变量的含义:存储信息的地方 创建变量并赋值 x = 1 print x x = 123 #再次赋值 print x (2)使用变量 x = 1 y = 2 z = 3 print x,y,x*y,z (3)变量的命名规则 由字母,数字,下划线组成 不能以数字开头 不能使用Python关键字 错误的变量命名举例: #name = 1 3k = 1 print = 1 英文字母大小写敏感,例如:m与M不同 m = 1 print M

黑马程序员——Java基础---io(上)

黑马程序员——Java基础---io(上) ------<a href="http://www.itheima.com" target="blank">Java培训.Android培训.iOS培训..Net培训</a>.期待与您交流! ------ 一.概述 Java I/O系统负责处理程序的输入和输出,I/O类库位于java.io包中,它对各种常见的输入流和输出流进行了抽象.如果数据流中最小的数据单元是字节,那么称这种流为字节流:如果数据流

nodejs学习笔记_nodejs和PHP在基础架构上的区别--共享状态的并发

绝大多数对于Node.js的讨论都把关注点放在了处理高并发能力上,做开发的时候一定要明白node内部做出的权衡,以及node应用性能好的原因. node 为javascript引入了一个复杂的概念,:共享状态的并发. node采用一个长期运行的进程 而php在apache中会产生多个进程 如下图所示: 代码验证: PHP: <?php $i = 0; $i++; echo $i nodejs: var http = require('http'); var i=0; http.createSer

C#基础(上)

第一章 开发入门 1-01 从一段代码开始 ①计算机语言 概念:人类与计算机沟通的工具 常见的计算机语言:C.PHP.Ruby.Java.C#.Basic.js.C++. ...等等 ②源代码 概念:用某种计算机语言编写的内容(目前C#源代码) 代码的执行:源代码→编译器compiler(负责编译的工具)→编译compile→机器代码101010100011111010 ③编译 将源代码转换成机器代码 拓展:软件开发中的常见术语 ①二进制 在我们现实世界中,有十个数字(0-9),因此,到达十的时