华为数通HCIP-MPLS

news2024/9/20 22:48:49

传统ip转发

路由器根据流量的dip查找路由表进行转发;

缺陷:查找路由表需要消耗一定CPU开销;(可以通过FIB表解决)

        安全性低,中间转发设备可以看到网络层ip信息;

FIB(转发信息库)

定义:精简版路由表,只将路由表中的转发信息(目的网段、掩码、下一跳、出接口)提取出来,下载到每个接口板中,当路由器需要查表接口板fib表,无需调用CPU;

特点:新增tunnel id

display fib    //查看fib表

MP-BGP

MP-BGPMultiprotocol Extensions for BGP-4)在RFC4760中被定义,用于实现BGP-4的扩展以允许BGP携带多种网络层协议(例如IPv6L3VPNEVPN等)。这种扩展有很好的后向兼容性,即一个支持MP-BGP的路由器可以和一个仅支持BGP-4的路由器交互。

 BGP-4扩展

BGP-4中IPv4特有的三个信息是NEXT_HOP属性、AGGREGATOR和IPv4 NLRI。因此为了支持多种网络层协议,BGP-4需要增加两种能力:
        关联其他网络层协议下一跳信息的能力。
        关联其他网络层协议NLRI的能力。
这种两种能力被互联网数字分配机构(IANA)统称为地址族(Address Family,AF)。
为了实现后向兼容性,协议规定MP-BGP增加两种新的属性,MP_REACH_NLRI和MP_UNREACH_NLRI,分别用于表示可达的目的信息和不可达的目的信息。这两种属性都属于可选非过渡(optional and non-transitive)。

 BGP-4规定IPv4的NEXT_HOP和AGGREGATOR属于Path attributes字段,IPv4的NLRI中携带IPv4的路由条目。
MP-BGP新增Path attributes的字段,将对应的网络层协议的NEXT_HOP字段和NLRI归属于MP_REACH_NLRI。MP_REACH_NLRI为Path attributes的新增字段。

MP_REACH_NLRI

MP_REACH_NLRI被携带于BGP Update报文中,有以下作用:
        通告可达的路由给BGP邻居
        通告可达路的路由的下一跳给BGP邻居
其详细字段如下:

 SAFI字段中1表示单播,2表示组播。值由IANA分配,其分配原则被定义于RFC2434(Guidelines for Writing an IANA Considerations Section in RFCs)。
本章节后续学习EVPN的AFI为25 (L2VPN) ,SAFI为70 (EVPN)。 

MP_UNREACH_NLRI

MP_UNREACH_NLRI被携带于BGP Update报文中,用于撤销不可达的路由。
其详细字段如下:
 

 例如EVPN的AFI为25 (L2VPN) ,SAFI为70 (EVPN)。 

MPLS简介

MPLSMultiprotocol Label Switching,多协议标记交换)

定义:在数据包的网络层以及数据链路层之间压入一层mpls层,其中会包含标签,中间设备根据标签查找标签转发表进行转发,不在查看路由表;

作用:

1、可以在转发过程中保护网络层头部;

2、减轻设备负担,加快转发速率(中间设备无需查看fib);
3、实现mpls vpn广域互联;
4、解决BGP路由黑洞的问题;

位于TCP/IP协议栈中的数据链路层和网络层之间,在两层之间增加了额外的MPLS头部。报文转发直接基于MPLS头部。MPLS头部又被称为MPLS标签(Label)。
MPLS以标签交换替代IP转发,实现了基于标签的快速转发。

 MPLS起源于IPv4(Internet Protocol version 4),其核心技术可扩展到多种网络协议,包括IPv6(Internet Protocol version 6)、IPX(Internet Packet Exchange)、Appletalk、DECnet、CLNP(Connectionless Network Protocol)等。MPLS中的“Multiprotocol”指的就是支持多种网络协议。
MPLS以标签交换替代IP转发。标签是一个短而定长的、只具有本地意义的连接标识符,与ATM的VPI/VCI以及Frame Relay的DLCI类似。
MPLS域(MPLS Domain):一系列连续的运行MPLS的网络设备构成了一个MPLS域。

LFIB(标签转发信息表)

内容:入标签、出标签、出接口、下一跳、FEC、tunnel id;
FEC:转发等价类,指具有相同转发特性的路由,可以直接看作为一条路由;

设备角色

入节点(ingress):入标签为null,负责根据出标签为数据包压入(push)标签;
中间节点(transit):负责根据收到数据包的标签,匹配入标签,并且将标签转换(swap)为出标签,再根据标签转发表中的出接口下一跳转发数据包;
出节点(egress):出标签为null,负责根据收到数据包的标签,匹配入标签,并且将对应标签弹出(pop),看到网络层头部,并且根据网络层头部的dip进行转发;

MPLS层

大小:4个字节(4B)

内容:

1、标签(label)20bit

        0~2的20次方-1

        0~15:保留标签,有固定用途;

                0:显式空标签

                3:隐式空标签

        16~1023为静态LSP的专属标签;(其中入标签范围为16~1023,出标签范围为16~2的20次方-1)

        1024~2的20次方-1:动态LSP专属;

2、EXP(实验位) 3bit

        0~7,代表数据包的优先级,类似于IPV4头部中的DSCP,提供给QOS使用;

3、S(栈底位) 1bit

        0 1,代表本层标签是否为最后一层;

        是----1

        否----0

4、TTL
        用于在mpls网络中防止流量无限转发;
        每经过一台设备的标签转发后会减1;

        TTL计算模式:
     (1)管道模式(华为默认)
              不管mpls网络多大,网络层头部的TTL值,只会在进入mpls域时以及离开mpls域时减1;
              优势:可以保护mpls网络的隐秘性;
              缺陷:出现故障时不好排查;
     (2)普通模式
              数据包在mpls网络中转发的过程中,mpls头部与ip头同步减少;
              优势:方便排障;
              缺陷:不安全;

LSP(标签交换路径)

定义:指从入节点到出节点,某一条FEC的完成标签交换路径;
构建方式:静态(手动配置)、动态(LDP)

LSR-ID

格式、大小:跟router id一致;
   作用:唯一标识一台mpls设备;
             作为传输地址(动态);
   特点:只能手工配置;
             必须可达(动态);

静态配置LSP:
[R1]mpls lsr-id 1.1.1.1         //指定LSR ID
[R1]mpls                             //全局下开启mpls

入节点:
[R1]static-lsp ingress 1 destination 4.4.4.4 32 nexthop 10.1.12.2 out-label 1000        //为4.4.4.4/32路由构建LSP,设置tunnel id为1,并且设置下一跳为10.1.12.2,出标签为1024

中间节点
[R2]static-lsp transit 1 incoming-interface GigabitEthernet 0/0/0 in-label 1000 nexthop 10.1.23.3 out-label 1001                    //注意下游设备的入标签需要跟上游设备的出标签一致,才能确保标签转发没有问题;

出节点
[R4]static-lsp egress 1 incoming-interface GigabitEthernet0/0/0 in-label 1002

所有物理接口下调用mpls;
interface GigabitEthernet0/0/0
mpls

优势:不交互报文,节省链路资源;

缺陷:配置量大;

        无法动态适应网络变化;

display mpls lsp verbose        //查看LFIB表

动态建立LSP

mpls ldp(标签分发协议)

[R1]mpls lsr-id 1.1.1.1           //指定LSR ID,必须可达
[R1]mpls                               //全局下开启mpls
      mpls ldp                         //全局下开启mpls ldp

所有物理接口下开启mpls以及mpls ldp;
interface GigabitEthernet0/0/0
 mpls
 mpls ldp

ldp报文:LDP——传输层头部——网络层头部——数据链路层头部
  LDP hello报文工作在UDP之上;
  其余的LDP报文工作在TCP之上;
  端口号:646
  hello报文的发送方式:组播发送(使用dip 224.0.0.2,代表网段内的所有路由器)
  其余报文的发送方式:单播发送;

mpls ldp工作过程


 1、发现阶段
      双方组播发送hello报文,用于发现邻居;
      告知对端自身的传输地址(默认为LSR ID)
      确认TCP连接的主动端,传输地址大的为主动端;

 2、建立TCP连接
      由主动端发起TCP三次握手连接请求,其中sip为自身的传输地址,dip为对方的传输地址;

 3、会话阶段
      由主动端发起,发送init报文,请求建立会话;
      协商参数:
     (1)LSR ID不能冲突;
     (2)标签空间id要一致;
      被动端收到init报文,会回应keepalive+init组合报文,其中keepalive部分用于确认建立主动端到被动端的会话,init部分用于请求建立被动端到主动端的会话;
      主动端收到后,回应keepalive报文,确认建立会话;
      双向会话建立完成;

      display mpls ldp peer         //查看ldp邻居

 4、通告阶段
      会话建立完成后,双方会交互address报文,用于告知对端自身有什么ip地址;
      每台LDP设备都会为自身的32位直连路由,由下游往上游逐跳分发标签;
      产生一个标签作为对应路由的入标签,并且通过mapping报文,发送给上游设备,上游设备收到后,会将该标签作为对应路由的出标签,并且产生一个入标签,继续向上游发送,直至入节点收到为止;
      
     当一台ldp设备收到一份mapping报文后,会做出以下检查:
      1、对应的FEC在本地FIB中是否存在路由;
      2、接收到该mapping报文的接口,是否为去往该路由的最优出接口;
      3、该mapping报文的发送者,是否为本设备去往该路由的最优下一跳;
     只有上述三个条件均满足,才能说明该标签是有效且最优的,才能作为出标签使用;

        4.1标签的分发方式:

         (1)DU(下游自主),华为默认

                会话建立完成后,所有LDP设备会为自身的32直连路由分配标签;

                缺陷:会产生无意义的隧道;

                优势:分配的效率高;

         

         (2)DOD(下游按需)

                下游设备需要等收到上游设备发送的label request报文,才会分配标签;

                缺陷:分配标签速率慢

                优势:按需分配标签,不会产生无意义的隧道;

        4.2 标签控制方式

        (1)有序模式(ordered),华为默认

                上游设备需要收到下游设备标签,才会继续向上游分发;

                优势:LSP的完整性能得到保障;

                缺陷:效率低;

        (2)独立模式(independent)

                上游设备无须收到下游设备的标签,即可向上游发送;

                优势:效率高;

                缺陷:可能会导致隧道不完整;

                如果mpls是用于解决BGP路由黑洞或者用于VPN时,可能会导致丢包;

        4.3 标签保持方式

        (1)自由模式(默认)

                对于次优标签,路由器也会接收,作为备份使用;

                优势:主备切换效率高;

                缺陷:设备需要维护多条LSP,开销较大;

        (2)保守模式

                对于次优标签,不接收

                优势:节省设备开销;

                缺陷:主备切换效率低;

display mpls ldp lsp //查看LDP建立的LSP的摘要信息;

 5、通知阶段(可选)
        如果LDP会需要关闭时(人为关闭MPLS,超过时间内没收到对方的keepalive......),则进入该阶段。进行TCP四次挥手拆除TCP连接;

**一台设备上一条FEC,出入标签可以一致的;

**一个出标签以及入标签,只能对应一条FEC,在一台设备上标签不能重复用于多条路由;

PHP(倒数第二跳弹出机制)

作用:减轻最后一跳设备的负担(正常标签转发过程中,最后一跳路由器需要先查看标签转发表,弹出标签,再根据dip查找fib,转发流量);

机制:ldp设备为自身的32位直连路由分配标签时,默认分配3号标签;

倒数第二跳路由器将标签swap成3号标签后,直接将mpls层剥离,然后根据标签转发表的出接口、下一跳进行发送,最后一跳路由器收到后,直接根据dip查找fib表转发;

[R4]route recursive-lookup tunnel //迭代隧道,如果一条路由的下一跳存在lsp隧道,那么可以将下一跳的隧道给该路由使用,前提是下一跳必须是32位的路由;一般用于解决BGP路由黑洞;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/802616.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Jmeter性能测试之正则表达式提取器

目录 前言 1. Jmeter正则表达式提取器 2. 入门实例 3. 进阶实例 前言 Jmeter正则表达式提取器属于Jmeter后置处理器(post processors)的一种,用于将取样器请求到的结果以正则表达式的方式读取出来。 1. Jmeter正则表达式提取器 1. 作用…

npm yarn nrm

npm 和 yarn npm和yarn都是包管理器,yarn是在2016年发布的,那时npm还处于V3时期,那时候还没有package-lock.json文件,不稳定性、安装速度慢等缺点经常会受到广大开发者吐槽。此时,yarn 诞生了。yarn 的优点&#xff0c…

iMessage 开发要点 坑点记录

pod 添加iMessage后,建议podfile要这样: platform :ios, 14.0def commonPod//这里写一些主应用和iMessage都要依赖的库pod "YYKit", ~> 1.0.9 endtarget MainApp doframeworksuse_frameworks!inhibit_all_warnings!# 多Target都有的podco…

【Lua学习笔记】Lua进阶——Require,三目运算

文章目录 Require短路判断实现三目运算符 Require 这是文件aaa.lua的内容 aaa.lua: a 10 local b 20 print("我是aaa")这是文件example.lua的内容 example.lua: a 100 print(a) require("aaa") --require调用其他脚本文件 print(a) print(b) print(&…

亚马逊云科技全新Amazon Bedrock,助力客户构建生成式AI应用

亚马逊云科技近日在纽约峰会上宣布全面扩展其全托管基础模型服务Amazon Bedrock,包括新增Cohere作为基础模型供应商,加入Anthropic和Stability AI的最新基础模型,并发布变革性的新功能Amazon Bedrock Agents功能。客户无需管理任何基础设施&a…

ceph集群中RBD的性能测试、性能调优

文章目录 rados benchrbd bench-write测试工具Fio测试ceph rbd块设备的iops性能测试ceph rbd块设备的带宽测试ceph rbd块设备的延迟 性能调优 rados bench 参考:https://blog.csdn.net/Micha_Lu/article/details/126490260 rados bench为ceph自带的基准测试工具&am…

OnnxRuntime TensorRT OpenCV::DNN性能对比(YoloV8)实测

1. 前言 之前把ORT的一套推理环境框架搭好了,在项目中也运行得非常愉快,实现了cpu/gpu,fp32/fp16的推理运算,同onnx通用模型在不同推理框架下的性能差异对比贴一下,记录一下自己对各种推理框架的学习状况 YoloV8模型大小 模型名称参数量NANO3.2M...... 2. CPU篇 CPU推理框架性…

【三维重建】SceneRF:基于NeRF的自监督单目三维场景重建

文章目录 摘要一、前言二、方法2.1.用于新的深度合成的NeRF3.1.1 深度估计 3.2 概率射线采样 (PrSamp)3.3 球形Unet(SU-net)3.4.场景重建方案 四、实验总结 摘要 从二维图像的三维重建被广泛的研究,训练与深度监督。为了放松对昂贵获取的数据…

火爆全网,Charles抓包教程-辅助接口测试(一)

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 charles是一款非常…

【C++进阶】多态的理解

一.多态是什么 多态是在不同继承关系的类对象,去调用同一函数,产生了不同的行为。 对于多态,不同的对象传过去,会调用不同的函数; 即多态调用看的是指向的对象。 //A,B类中的func函数是个多态 class A { pu…

自制Nuget包(C#)

自制Nuget包 自制C# Nuget包。 目的: 生成一个可以通过Nuget管理自动应用的包,生成效果如图: 步骤: 整个制作过程分为两步:第一步制作Nuget包,第二步上传Nuget包到Nuget网站(地址&#xf…

Redis实战(2)——互斥命令用于构建分布式锁

1 什么是分布式锁 在单体应用中,线程锁是可以让多个线程串行执行一段代码逻辑的。不过在集群环境或者是分布式的环境下,线程锁无法保证线程串行运行,从而出现线程安全的问题。 根本的原因在于,在 集群分布式环境下 \textcolor{r…

F12 浏览器调试模式页面刷新 network 日志刷新消失的解决办法

每次请求刷新后都把之前的请求记录刷新掉了,把preserve log勾选上后,所有的请求都会保留,再也不怕抓不到记录了。

配置 gitlab https 访问

文章目录 1. 备份2. 生成SSL证书3. 配置文件4. 重启5. 访问 1. 备份 docker exec -ti gitlab-ce gitlab-rake gitlab:backup:create2. 生成SSL证书 yum install openssl openssl-devel -y mkdir /data/gitlab/config/ssl ; cd /data/gitlab/config/ssl### 生成证书 openssl…

郑州Sectigo DV通配符SSL证书

我们在浏览器访问网页时或许不会注意到网站是http还是https链接,但是一定能注意到浏览器给我们展示的“不安全”警告,警告访问者网站未加密,访问网站会有泄露隐私的危险。SSL证书能将网站链接由http转为https,对网站传输数据加密&…

数据科学复现

片段 线性回归建模步骤.py 用sklearn做简单的一元线性回归.py 红用逻辑回归实现红酒数据分类py 高斯朴素贝叶斯分类py

uni-app如何生成正式的APK

第一步: 进入dcloud官网https://dcloud.io/,点击开发者后台进入登录注册页面 第二步:登录之后跳到项目列表,选择自己想要打包的项目 点击进去如果没有生成证书,点击生成证书,如果显示证书已生成就不用管了…

什么样的程序员在35岁后仍然保持竞争力?

作为程序员,大家肯定都听说过程序员的35岁危机,有的人刚入职程序员这个岗位就开始为自己的未来担忧,然而,与其担心自己35岁以后被优化掉,不如现在想想,怎么让自己到了35岁以后在这个岗位上依旧有竞争力。今…

【Python】在PyCharm中安装 ChatGPT 插件,让 AI 帮助我们写代码,从此代码再无报错,小白也能轻易上手!!!

前言 ChatGPT是目前最强大的AI,不仅能够聊天、写小说,甚至码代码也不在话下。 但是在国内要使用chatgpt很麻烦,国内一家团队开发了一款idea插件NexChatGPT,用数据代理的方式,让我们在国内也能轻松的使用chatgpt。 没…