网络知识点之—EVPN

EVPN(Ethernet Virtual Private Network)是下一代全业务承载的VPN解决方案。EVPN统一了各种VPN业务的控制面,利用BGP扩展协议来传递二层或三层的可达性信息,实现了转发面和控制面的分离。

EVPN解决传统L2VPN的无法实现负载分担、网络资源的消耗较高等不足,同时也可以对L3VPN业务进行承载,降低了协议的复杂程度。EVPN还将IP VPN流量均衡和部署灵活的优势引入到了以太网中。种种优势使其广泛应用于大型数据中心二层网络互连场景。

起源与发展

最初的VXLAN方案(RFC7348)中没有定义控制平面,VXLAN隧道需要手工配置,然后通过流量泛洪的方式进行主机地址的学习。这种方式实现上较为简单,但是会导致网络中存在很多泛洪流量、网络扩展困难。

为了解决上述问题,人们在VXLAN中引入了EVPN作为VXLAN的控制平面。

EVPN是一种用于二层网络互联的VPN技术,它颠覆了传统二层VPN通过转发面来学习MAC地址的机制,引入了控制面,利用BGP扩展协议来传递MAC信息,有望取代其他 L2VPN 传输方法,例如基于 BGP 的 L2VPN (RFC6624)、基于 LDP 的 L2VPN (RFC4906) 和 VPLS。

了解 EVPN

EVPN可通过 IP 或 IP/MPLS 骨干网在不同的二层域之间提供虚拟多点桥接连接。与 IP VPN 和VPLS(虚拟专用 LAN 服务 ) 等其他 VPN 技术一样,EVPN 在PE (提供商边缘) 路由器上配置实例,以确保客户之间的逻辑业务分离。

PE 路由器用于连接到CE (客户边缘) 设备,这些设备可以是路由器、交换机或主机。然后,PE 路由器使用MP-BGP (多协议 BGP)交换可达性信息,并在 PE 路由器之间转发封装的流量。由于该架构的元素与其他VPN技术是通用的,因此EVPN可以无缝引入并集成到现有的业务环境中,如下所示:

93229488422f4c2b935d40be675a688d.png

 EVPN 可用作二层 Overlay 解决方案,以便在裸机服务器等终端站需要二层连接时,通过 IP 底层为虚拟网络中的端点提供二层连接。

EVPN 的 MP-BGP 控制平面能够动态地将实时虚拟机从一个数据中心迁移到另一个数据中心,称为VM(虚拟机) 迁移。将 VM 移动到目标服务器或管理程序后,它会发送一个免费 ARP,更新目标数据中心 PE 设备的二层转发表。然后,PE 设备将 MAC 路由更新发送到所有远程 PE 设备,这些设备依次更新它们的转发表。

EVPN 的优势

简化配置:通过MP-BGP实现VTEP自动发现、VXLAN隧道自动建立、VXLAN隧道与VXLAN自动关联,无需用户手工配置,降低网络部署难度。

 

分离控制平面与数据平面:控制平面负责发布路由信息,数据平面负责转发报文,分工明确,易于管理。

支持多归属:当同一个站点通过多台VTEP接入VXLAN网络时,连接该站点的多条路径均可以进行流量转发,以提高网络带宽利用率。

支持对称IRB(Integrated Bridging and Routing,集成的桥接和路由):MP-BGP同时发布二层MAC地址和三层路由信息,VTEP既可以进行二层转发,也可以进行三层路由。

什么是 BGP EVPN

BGP(特别是MP-BGP)从早期开始就是 EVPN 控制平面的选择。BGP EVPN 的基本思想如下所示,以太网网络通过中间 IP 网络连接,标记为 IP 底层。PE路由器实施 BGP EVPN 协议并通过 IP 网络相互对等。

1bba13fda356411f995177c75bf67a4f.png

 EVPN NLRI定义了五种EVPN路由类型来解决不同的用例。其中Type1~Type4是在 RFC7432中定义的,Type5是在后来的草案中定义的。

Type1:Ethernet auto-discovery (AD) route,用来在站点多归属组网中通告ES信息,以便实现水平分割、Aliasing和主备备份等特性。

Type2:MAC/IP advertisement route,用来通告MAC/IP地址信息。

Type3:Inclusive multicast Ethernet tag route,用来通告VTEP及其所属VXLAN,以实现VTEP自动发现、自动建立VXLAN隧道、自动创建VXLAN广播表等。

Type4:Ethernet segment route,用来通告ES及其连接的VTEP信息,以便发现连接同一ES的VTEP冗余组其他成员,以及在冗余组之间选举指定转发器DF等。

Type5:IP prefix route,IP前缀路由,用来以IP前缀的形式通告引入的外部路由。

BGP 在实现 EVPN 扩展需求方面发挥了一些关键作用:

1)从数据平面中删除 MAC 地址学习。在标准以太网网络中,MAC 地址是通过交换机在传输时观察帧(数据包)来学习的。每当交换机遇到未知的目标 MAC 地址时,它就会泛洪帧,即将其复制到所有可能的目标。这种类型的未知单播帧泛洪可能导致流量拥塞,可能包括广播风暴,并且扩展性非常差。

2)减少广播和多播流量负载。与未知的单播泛洪类似,广播和多播流量会在网络上造成沉重的流量负载,并有可能因广播风暴而中断。BGP EVPN 可以通过有选择地转发此类流量来减少这些问题。

3)跨底层 IP 网络实现最佳转发、负载平衡和收敛。

BGP EVPN 如何作为 VXLAN 的控制平面

在采用BGP EVPN部署分布式VXLAN网关的场景下,控制平面负责VXLAN隧道建立和动态MAC地址学习,转发平面负责子网内已知单播报文转发、子网内BUM报文转发和子网间的数据包转发。BGP EVPN提供多种功能,包括主机IP路由通告、主机MAC地址通告、主机ARP通告和ARP广播抑制。如果分布式网关部署在VXLAN网络中,推荐使用BGP EVPN。

以下内容以具有IPv4 Underlay和Overlay网络的VXLAN网络为例,描述BGP EVPN如何作为VXLAN的控制平面工作。

子网内 VXLAN 隧道建立

VXLAN隧道由一对VTEP(VXLAN隧道端点)决定。在子网内通信场景中,当两个VTEP之间的IP地址路由可达时,可在它们之间建立VXLAN隧道,因为它们只需要在同一个二层BD(广播域)中进行通信。当使用EVPN动态建立VXLAN隧道时,两个VTEP建立BGP EVPN对等体关系,并交换Type 3路由,传递VNI和VTEP IP地址信息。然后在它们之间动态建立 VXLAN 隧道。

通过 EVPN 学习 MAC 地址

当EVPN作为VXLAN的控制平面时,可以用EVPN来进行MAC学习,以替代数据平面泛洪方式的MAC学习,减少泛洪流量。使用EVPN来进行MAC学习的过程,是通过在VTEP之间传递Type2路由完成的。

下图举例说明VTEP是如何通过EVPN学习远程主机的MAC地址。

a37accc84a8e4c39bd7893fe38a27e09.png

子网间 VXLAN 隧道建立和路由通告

主机路由通告

EVPN Type 2 路由既可以通告主机 MAC 地址和主机路由,因为 Type 2 路由可以携带具有 32 位掩码的主机 IP 地址。主机路由通告使不同网段上的主机能够在分布式网关场景下相互通信。

VTEP 需要相互通告连接主机的 IP 路由。否则,对端VTEP无法获知连接到本地VTEP的主机的路由信息,并且无法在三层主机之间转发子网间报文的转发。

网段路由通告

通告网段路由的过程与通告主机路由的过程类似,不同的是网段路由通过Type 5路由进行通告,而Type 2路由只能通告32位或128位的主机路由。对于32位或128位主机路由的通告,Type 5路由的作用与Type 2路由类似。

如果网关设备下连接的网段在整个网络中唯一,则可以配置发布网段路由,否则不能配置发布网段路由。

子网内 BUM 报文转发

当接收到一个主机到同一子网内另一个主机的 BUM 数据包时,VTEP 会将数据包发送到连接到同一子网上的主机的所有 VTEP。

子网间报文转发

在下图分布式网关场景中,Leaf1和Leaf2作为三层VXLAN网关,进行VXLAN封装和三层转发。Spine节点仅作为VXLAN报文转发节点,不处理VXLAN报文。

176c7264ddd44c39851a32beea7cffe0.png

 VXLAN BGP EVPN 网络上的 ARP 广播抑制

ARP 广播到单播的转换

设备将广播ARP报文转换为单播ARP报文,然后以单播的方式转发。ARP广播到单播的转换过程如下:三层VXLAN网关根据ARP表项生成ARP广播抑制表项(包含主机IP地址、MAC地址、VNI、VTEP IP地址信息),并将主机信息发送给通过 EVPN 的二层网关。二层网关收到广播ARP Request报文后,用学习到的主机MAC地址替换原来所有Fs的原始广播MAC地址。这样,二层网关就可以将广播报文转换为单播报文进行转发。

二层代理 ARP

使用ARP广播转单播功能实现ARP广播抑制时,需要三层网关。在纯二层网络中,没有三层网关可以学习到主机的ARP表项,这样就没法生成ARP广播抑制表项来抑制ARP广播报文。上述二层场景下的ARP广播抑制可以通过二层代理ARP功能实现。

总 结

传统的BGP-4使用Update报文在对等体之间交换路由信息。一条Update报文可以通告一类具有相同路径属性的可达路由,这些路由放在NLRI(网络层可达信息)字段中。因为BGP-4只能管理IPv4单播路由信息,为了提供对多种网络层协议的支持(例如IPv6、组播),发展出了MP-BGP。

MP-BGP在BGP-4基础上对NLRI作了新扩展。玄机就在于新扩展的NLRI上,扩展之后的NLRI增加了地址族的描述,可以用来区分不同的网络层协议,例如IPv6单播地址族、VPN实例地址族等。

类似的,EVPN也是借用了MP-BGP的机制,在L2VPN地址族下定义了新的子地址族——EVPN地址族,在这个地址族下又新增了一种NLRI,即EVPN NLRI。EVPN NLRI定义了几种BGP EVPN路由类型,这些路由可以携带主机IP、MAC、VNI、VRF等信息。这样,当一个VTEP学习到下挂的主机的IP、MAC地址信息后,就可以通过MP-BGP路由将这些信息发送给其他的VTEP,从而在控制平面实现主机IP、MAC地址的学习,抑制了数据平面的泛洪。

EVPN技术不仅被考虑用于 DC 流量,还可以用于即将到来的 5G 流量和相关应用。

 

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《神经网络》—— 长短期记忆网络(Long Short-Term Memory,LSTM)

文章目录 一、LSTM的简单介绍二、 LSTM的核心组件三、 LSTM的优势四、 应用场景 一、LSTM的简单介绍 传统RNN循环神经网络的局限: 示例:当出现“我的职业是程序员。。。。。。我最擅长的是电脑”。当需要预测最后的词“电脑”。当前的信息建议下一个词可…

[Python] 使用Python自定义生成二维码

文章目录 目录 安装 qrcode 库生成简单的二维码代码讲解 生成自定义样式的二维码代码讲解 生成带有链接的二维码代码讲解 Demo代码实现代码讲解 总结 收录专栏: [Python] 二维码是现在非常常用的一种信息存储和传递方式,我们可以通过扫描二维码来快速获取文本、链接…

如何在测试中模拟请求和响应?

在日常开发中,除了在服务器端进行单元测试之外,还经常需要做集成测试,为了能更好地做一些边界测试,我们常常需要mock一些HTTP请求或者响应,今天我们就来聊聊几种常见的方式。 服务器端设置 在开发中,我们…

车辆路径规划问题(VRP)优化方案

车辆路径规划问题(VRP)优化方案 车辆路径规划问题(Vehicle Routing Problem, VRP)是物流领域中一个经典的组合优化问题,目标是在满足客户需求的情况下,找到一组车辆的最优配送路径,以最小化总的…

C/C++复习(一)

1.sizeof 关于sizeof我们是经常使用的,所以使用方法就不需要提及了,这里我们需要注意的是,sizeof 后面如果是表达式可以不用括号,并且sizeof实际上不参与运算,返回的是内容的类型大小(size_t类型&#xff0…

CDN绕过学习

1.什么是CDN? CDN就是分布在各个地区的服务器,这些服务器储存着数据的副本。 哪些服务器比较接近你,当你发起请求时,提前就会快速为你提供服务。 总结来说就是: 其实就是用来加速访问的,以及缓解压力&a…

提示工程、微调和 RAG

自众多大型语言模型(LLM)和高级对话模型发布以来,人们已经运用了各种技术来从这些 AI 系统中提取所需的输出。其中一些方法会改变模型的行为来更好地贴近我们的期望,而另一些方法则侧重于增强我们查询 LLM 的方式,以提…

1. Keepalived概念和作用

1.keepalived概念 (1)解决单点故障(组件免费) (2)可以实现高可用HA机制 (3)基于VRR协议(虚拟路由沉余协议) 2.keepalived双机主备原理

一入递归深似海,算法之美无止境

最近在刷leetcode hot100,在写二叉树中最大路径和的时候,看到了一个佬对递归的理解,深受启发,感觉自己对于递归的题又行了!!! 这里给大家分享一下(建立大家先去尝试一下这道题再来看 124. 二叉树中的最大路径和 二叉树中的 路径 被定义为一条节点序列,序列中每…

什么是PLM系统?PLM系统对制造业起到哪些作用?三品PLM系统对汽车制造业意义

在当今竞争激烈的制造业环境中,企业面临着来自市场、技术、客户需求等多方面的挑战。为了应对这些挑战,许多制造企业纷纷引入产品生命周期管理PLM系统,以实现更高效、更灵活的产品全生命周期管理。PLM系统以其独特的优势,在优化产…

智能猫砂盆怎么选购?cewey、鸟语花香、霍曼全方位测评性能大PK

智能猫砂盆怎么选购?cewey、鸟语花香、霍曼全方位测评性能大PK 现在的生活节奏越来越快,我们经常会外出不在家,这时候猫咪的粑粑就不能及时清理,会出现猫咪嫌猫砂盆脏乱拉,家里空气也会充满臭味。针对这个问题&#x…

Unity3d动画插件DoTween使用指南

1、DoTween是什么? DoTween是一款对象动画类插件,它是一款针对Unity 3D编辑器的、快速高效的、安全的、面向对象的补间动画引擎,并且对C#语言开发做出了很多的优化。另外,它使得开发者无需通过Unity内置的Animator或Coroutines即可…

【Chrome浏览器插件--资源嗅探猫抓】

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、资源嗅探插件---猫抓二、使用步骤总结 一、资源嗅探插件—猫抓 猫抓是一个浏览器插件,可以检测当前网页中的一些资源文件,可设置嗅探的…

用KLineChart绘制股票行情K线图

用KLineChart绘制股票行情K线图 先看效果集成过程集成到系统 先看效果 用klinechart开源代码集成到系统中,展示的K线图效果。 集成过程 KlineChart源码地址: https://github.com/klinecharts/KLineChart KlineChart提供了多种行情分析指标 集成到…

OJ在线评测系统 微服务高级 Gateway网关接口路由和聚合文档 引入knife4j库集中查看管理并且调试网关项目

Gateway微服务网关接口路由 各个服务之间已经能相互调用了 为什么需要网关 因为我们的不同服务是放在不同的端口上面的 如果前端调用服务 需要不同的端口 8101 8102 8103 8104 我们最好提供一个唯一的 给前端去调用的路径 我们学习技术的时候必须要去思考 1.为什么要用&am…

Python | Leetcode Python题解之第458题可怜的小猪

题目: 题解: class Solution:def poorPigs(self, buckets: int, minutesToDie: int, minutesToTest: int) -> int:if buckets 1:return 0combinations [[0] * (buckets 1) for _ in range(buckets 1)]combinations[0][0] 1iterations minutesT…

JavaSE——集合1:Collection接口(Iterator和增强for遍历集合)

目录 一、集合框架体系(重要) 二、集合引入 (一)集合的理解与好处 三、Collection接口 (一)Collection接口实现类的特点 (二)Collection接口常用方法 (三)Collection接口遍历元素的方式(Iterator和增强for) 1.使用Iterator(迭代器) 1.1Iterator(迭代器)介绍 1.2Itera…

[含文档+PPT+源码等]精品基于Nodejs实现的家教服务小程序的设计与实现

基于Node.js实现的家教服务小程序的设计与实现背景,主要源于以下几个方面: 一、家教市场的现状与需求 随着教育竞争的日益激烈,家庭对子女教育质量的重视程度不断提升,家教服务已成为许多家庭不可或缺的一部分。然而&#xff0c…

graphql--快速了解graphql特点

graphql--快速了解graphql特点 1.它的作用2.demo示例2.1依赖引入2.2定义schema2.3定义GrapQL端点2.4运行测试2.5一些坑 今天浏览博客时看到graphQL,之前在招聘网站上第一次接触,以为是图数据查询语言, 简单了解后,发现对graphQL的介绍主要是用作API的查询语言,不仅限于图数据查…

Meta 发布 Quest 3S 头显及 AR 眼镜原型:开启未来交互新视界

简介 在科技的浪潮中,Meta 始终站在创新的前沿,不断为我们带来令人惊叹的虚拟现实和增强现实体验。2024 年 10 月 6 日,让我们一同聚焦 Meta 最新发布的 Quest 3S 头显及 AR 眼镜原型(Orion),探索这两款产品…