BGP路由选路

2023-10-27 19:40
文章标签 路由 bgp 选路

本文主要是介绍BGP路由选路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

BGP路由选路

  • 一、路径属性定义?
  • 二、路径属性分类
  • 三、BGP选路原则
    • 1.最常用的三种方法
  • 三、BPG路由反射器
  • 四、路由选路实验拓展
  • 总结

一、路径属性定义?

  • 路径属性: path attributes,作用类似于metric,用于度量BGP的路由优劣(用来进行选路)

二、路径属性分类

1、公认强制属性:所有的BGP的update消息都要包含该属性

AS路径(As-path)(可用于防环)
下一跳(next-hop)
起源(origin)

2、公认自由属性:该属性是可选可不选的,但是所有的BGP进程都能识别

本地优先级(local preferent)

3、可选传递属性:即使BGP进程不能识别该属性,也会继续传递下去

团体属性(community)

4、可选非传递属性:如果BGP进程不能识别该属性,可以忽略这条update,并且不传递下去

MED属性

三、BGP选路原则

1、如果此路由的下一跳不可达,忽略此路由
2、 Preferred-Value值数值越高越优先,华为私有属性,仅本地有意义(很少用到)
3.、Local-Preference值越高的路由越优先
4、聚合路由优先于非聚合路由
5、本地手动聚合路由的优先级高于本地自动聚合的路由
6、本地通过Network命令引入的路由的优先级高于本地通过Import-route命令引入的路由7、As-path的长度越短的路径越优先
8、比较origin属性, IGP优于EGP, EGP优于Incomplete(可控的不多)
9、选择MED较小的路由(MED的值越小越优先)
10、EBGP路由优于IBGP路由
11、BGP优先选择到BGP下一跳的IGP度量值最低的路径

当以上全部相同,则为等价路由,可以负载分担(注意: As Path必须一致,当负载分担时,以下3条原则无效)
12、比较Cluster list长度,短者优先
13、比较originator ID (如果没有0riginator ID,则用Router ID比较) ,选择数值较小的路径。
14、比较对等体的IP地址,选择IP地址数值最小的路径。

1.最常用的三种方法

(一)、根据local-prefernce控制选路(越大越优)
配置命令如下


[R3] route-policy lop permit node 10        ###创建名为Lop的路由策略
[R3-route-policy] apply local-prefernce 222 ##设置本地优先级为222(默认优先级是100[R3-route-policy]quit
[R3]bgp 200
[R3-bgp]peer 4.4.4.4 route-policy lop export ####在R3上对R4执行出站export方向的路由策略,
使得R4在收到R3通告的路由后,在路由的local-prefernce的属性值改为222使得R4优选R3通告的路由;如果
此路由策略在R4配置则方向为入站import
reset bgp all ##重启BGP
refresh bgp all export软重启

(二)、使用AS-PATH属性控制选路(越少越优)
配置命令如下

apply as-path xxx additive          ###在已有AS Path基础上追加xxx
apply as-path xxx overwrite         ###将已有AS Path值替换(覆盖)成xxx
apply as-path none overwrite        ###清空路亩的AS Path属性[R2] route-policy as permit node 10
[R2-route-policy]apply as-path 123 123 123 additive   ##在已有AS Path基础上追加
[R2-route-policy]quit
[R2]bgp 200
[R2-bgp]peer 1.1.1.1 route-policy as export
<R2>reset bgp all
<R2>refresh bgp all export

(三)、通过MED属性控制选路(越小越优)

[R2] route-policy med permit node 10
[R2-route-policy] apply cost + 500/- 500
[R2-route-policy]quit
[R2]bgp 200
[R2-bgp]peer 1.1.1.1 route-policy med export
< R2 >reset bgp all
< R2 >refresh bgp all exportdisplay bgp routing-table        ###查BGP的路由表
display bgp routing-table 目标网段       ##查看详细信息

(四)、多网段情况下只匹配某一网段选路

ip ip-prefix 1 permit 100.0.1.0 24
route-policy RP permit node 10
if-match ip-prefix 1 ###默认拒绝所有
apply origin incomplete
route-policy RP permit node 20bgp 100
network 100.0.1.0 24
peer 10.1.13.3 as-number 345
peer 10.1.13.3 route-policy RP export
  • Origin属于公有必遵,用来定义路径信息的来源,其作用是标记一条路由是怎么成为BGP路由的, EBGP邻居之间起作用,它有三种属性:
  • IGP (i) :优先级最高
  • EGP(e):优先级次之
  • Incomplete (? ) :优先级最低

三、BPG路由反射器

  • 在AS内部,为保证IBGP对等体之间的连通性,需要在IBGP对等体之间建立全连接关系。当IBGP对等体数目很多时,建立全连接网络的开销很大。使用路由反射器RR
    (Route Reflector)可以解决这个问题。
  • 集群ID用于防止集群内多个路由反射器和集群间的路由环路。当一个集群里有多个路由反射器时,必须为同一个集群内的所有路由反射器配置相同的集群ID。

--------RR向IBGP邻居发布路由规则如下:(相当于中继的作用)
1、从非客户端学到的路由,发布给所有客户端。
2、从客户端学到的路由,发布给所有非客户端和客户端(发起此路由的客户端除外) 。
3、从EBGP对等体学到的路由,发布给所有的非客户端和客户端。

四、路由选路实验拓展

在这里插入图片描述

  • R1配置

在这里插入图片描述
R2配置在这里插入图片描述
R3配置在这里插入图片描述
R4配置
在这里插入图片描述
R5配置
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

总结

以上是我对路由选路规则和反射器原理的理解,如有不对,请大佬指出。

这篇关于BGP路由选路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/287933

相关文章

【vue3|第28期】 Vue3 + Vue Router:探索路由重定向的使用与作用

日期:2024年9月8日 作者:Commas 签名:(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释:如果您觉在这里插入代码片得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^ 1.01365 = 37.7834;0.99365 = 0.0255 1.02365 = 1377.4083;0.98365 = 0.0006 说

HCIA--实验十:路由的递归特性

递归路由的理解 一、实验内容 1.需求/要求: 使用4台路由器,在AR1和AR4上分别配置一个LOOPBACK接口,根据路由的递归特性,写一系列的静态路由实现让1.1.1.1和4.4.4.4的双向通信。 二、实验过程 1.拓扑图: 2.步骤: (下列命令行可以直接复制在ensp) 1.如拓扑图所示,配置各路由器的基本信息: 各接口的ip地址及子网掩码,给AR1和AR4分别配置

微信小程序路由跳转之间的区别

navigateTo: 功能描述: navigateTo用于保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。 页面栈变化: 当使用navigateTo进行页面跳转时,当前页面会被推入页面栈中,但不会被销毁,新页面则显示在屏幕上。因此,页面栈中的元素数量会增加。 注意:一般定制返回时候不要用navigateTo,用navigateBack,否则会导致页面栈过多。 nav

如何为 DigitalOcean 静态路由操作员设置故障转移

静态路由操作器的主要目的是提供更大的灵活性,并在 Kubernetes 环境中控制网络流量。它使你能够根据应用程序的需求自定义路由配置,从而优化网络性能。该操作器作为 DaemonSet 部署,因此将在你的 DigitalOcean Managed Kubernetes 集群的每个节点上运行。 在本教程中,你将学习如何根据 CRD 规范管理每个工作节点的路由表,并设置故障转移网关。

若依框架登录鉴权详解(动态路由)

若依框架登录鉴权:1.获取token(过期在响应拦截器中实现),2.基于RBAC模型获取用户、角色和权限信息(在路由前置守卫),3.根据用户权限动态生成(从字符串->组件,根据permission添加动态路由信息)和添加路由addRoutes(在路由前置守卫) 若依框架(Ruoyi)后端的登录权限身份认证流程是一个复杂但高效的过程,它确保了系统的安全性和数据的保护。以下是一个典型的若依

Vue - 关于Router路由跳转时显示的animate.css动画

Vue - 关于Router路由跳转时显示的animate.css动画 在Vue中,操作路由跳转时页面是闪白的,没有动画效果,我们可以通过在router-view中设置transition,并搭配animate丰富的动画效果来美化路由跳转时的显示效果. 1.安装animate npm i -S animate.css 2.在main中引入animate.css import 'anim

Avoided redundant navigation to current location: 路由相同报错

vue-router有一个内置保护机制,它会阻止不必要的重复导航,以提高性能并避免不必要的计算。 具体来说,错误信息中的就是试图访问的路径时,应用程序已经在当前这个路径上。因此,vue-router检测到了这个重复的导航请求,就发出了警告。 通常情况下,这种警告并不需要特别处理,因为这只是一个优化措施,防止不必要的导航。但是如果你频繁遇到这种情况,可能需要检查触发导航的部分代码逻辑是否有必要进

直接路由配置集群通信---------通过quagga 动态添加服务器路由规则

上一篇微博提到关于使用直接路由的方式配置集群通信,其优点很明确,简单易懂,但是缺点也是不容忽视的。假设一下,你的集群里面有100甚至是上千个node,在每个服务器上,你都得去配置到其他所有node的静态路由,其工作量是庞大切枯燥的。 这里我详细介绍一下,使用quagga来动态添加路由规则。软件主页http://www.quagga.net。 最简单的方式当然是直接在每台服务器上安装quagga

使用直接路由配置kubernetes 集群

通过在每个node 上添加其他node的docker0 网桥的静态路由规则,就可以实现docker0 网桥的互通了。 这种方法需要在每个node的路由表中增加到对方docker0 的静态路由规则,以下例子:      pod1 所在docker0网桥的ip子网10.1.10.0,该node 姑且叫做node1,其地址为192.168.1.128; pod2 所在docker0网桥的ip子网1

Vue的路由跳转

文章目录 基本语法1. **使用路径字符串跳转**2. **使用命名路由跳转**3. **传递参数****带路径参数****带查询参数****结合 `params` 和 `query`** 4. **替换导航 (replace)**5. **导航失败的处理**6. **返回上一页或前进**总结 this.$router.push() 是 Vue Router 提供的导航方法,用