BGP的local_preference本地优先级属性

一、BGP的local preference属性简介

1、local preference公认任意属性

当一条BGP路由器中存在多条去往同一目标网络的BGP路由时,BGP协议会对这些BGP路由属性进行比较,从而筛选出最佳到达目标网络的通达路径。本地优先属性,只在IBGP对等体之间进行交换,即:同一AS内进行,不会通告给AS域外。

Local Preference属性可以用于选择流量离开AS时的最佳路由,也就是控制流量从哪个出口离开AS。当BGP路由器通过不同的IBGP对等体接收到目标网络相同但下一跳不同的多条路由时,将优先选择Local Preference值较高的路由。

2、BGP使用local preference属性的规则:

(1)在BGP优选路由的时候,在preference value 相同的情况,进而判断local_prefrence值越大越优先。Local_prefrence值是一个32比特的整数,取值范围为0~4294967295。默认情况BGP 路由的local preference value 为100。

(2)local_prefrence 只在IBGP对等体进行传播。当路由器从IBGP对等体接收路由的local_prefrence 值为空时,那么会将此路由的local_prefrence 设置为100,即:在IBGP对等体传递路由,默认值为100。

(3)当路由器从IBGP对等体接收路由的local_prefrence值不为空时,那么将此路由的local_prefrence 进行保留,不做修改。

(4)使用network通告或的import-route 引入的路由,local_prefrence 值为空。

(5)路由器在向其EBGP对等体发送路由更新时,不能携带Local Preference属性,但是对方接收路由之后,会在本地为这条路由赋一个缺省Local Preference值( 100),然后再将路由传递给自己的IBGP对等体。本地使用network命令引入及重发布引入的路由,Local Preference为缺省值100,并能在AS内向其他IBGP对等体传递,传递过程中除非受路由策略影响,否则Local Preference不变。

(6)可以在AS边界路由器上使用import方向的策略来修改Local Preference属性值。也就是在收到路由之后,在本地为路由赋予Local Preference。

二、拓扑图

说明:

1、为展示Local_prefrence本地优先级属性,AR2与AR3通过loopback0建立BGP邻居关系,AR1与AR2之间采用物理链路的接口ip地址建立邻居关系。

2、AR1的loopback1地址模拟运营商网络的服务器,AR4的loopback1地址模拟公司内网的服务器。

3、采用路由策略route-policy抓取模拟服务器的路由,在AR2的G0/0/0接口修改local prefrence属性值,再观察BGP路由的变化。

三、配置过程

1、配置AR1

System-view

sysname AR1

interface GigabitEthernet0/0/0

ip address 10.1.12.1 255.255.255.0

interface GigabitEthernet0/0/1

ip address 10.1.13.1 255.255.255.0

interface LoopBack0

ip address 1.1.1.1 255.255.255.255

interface LoopBack1

ip address 10.1.100.2 255.255.255.255

bgp 100

peer 3.3.3.3 as-number 200

peer 3.3.3.3 ebgp-max-hop 255

peer 3.3.3.3 connect-interface LoopBack0

peer 10.1.12.2 as-number 200

peer 10.1.12.2 ebgp-max-hop 255

ipv4-family unicast

undo synchronization

network 10.1.100.2 255.255.255.255

peer 3.3.3.3 enable

peer 10.1.12.2 enable

ospf 1

area 0.0.0.0

network 1.1.1.1 0.0.0.0

network 10.1.12.0 0.0.0.255

network 10.1.13.0 0.0.0.255

network 10.1.100.2 0.0.0.0

2、配置AR2

System-view

sysname AR2

interface GigabitEthernet0/0/0

ip address 10.1.12.2 255.255.255.0

interface GigabitEthernet0/0/1

ip address 10.1.24.2 255.255.255.0

interface LoopBack0

ip address 2.2.2.2 255.255.255.255

bgp 200

peer 3.3.3.3 as-number 200

peer 3.3.3.3 connect-interface LoopBack0

peer 4.4.4.4 as-number 200

peer 4.4.4.4 connect-interface LoopBack0

peer 10.1.12.1 as-number 100

peer 10.1.12.1 ebgp-max-hop 255

ipv4-family unicast

undo synchronization

peer 3.3.3.3 enable

peer 3.3.3.3 next-hop-local

peer 4.4.4.4 enable

peer 4.4.4.4 next-hop-local

peer 10.1.12.1 enable

peer 10.1.12.1 route-policy 1 import

peer 10.1.12.1 route-policy 1 export

ospf 1

area 0.0.0.0

network 2.2.2.2 0.0.0.0

network 10.1.12.0 0.0.0.255

network 10.1.24.0 0.0.0.255

route-policy 1 permit node 10

if-match ip-prefix 1

apply local-preference 2

route-policy 1 permit node 20

ip ip-prefix 1 index 10 permit 10.1.100.2 32

3、配置AR3

System-view

sysname AR3

interface GigabitEthernet0/0/0

ip address 10.1.34.3 255.255.255.0

interface GigabitEthernet0/0/1

ip address 10.1.13.3 255.255.255.0

interface LoopBack0

ip address 3.3.3.3 255.255.255.255

bgp 200

peer 1.1.1.1 as-number 100

peer 1.1.1.1 ebgp-max-hop 255

peer 1.1.1.1 connect-interface LoopBack0

peer 2.2.2.2 as-number 200

peer 2.2.2.2 connect-interface LoopBack0

peer 4.4.4.4 as-number 200

peer 4.4.4.4 connect-interface LoopBack0

ipv4-family unicast

undo synchronization

peer 1.1.1.1 enable

peer 2.2.2.2 enable

peer 2.2.2.2 next-hop-local

peer 4.4.4.4 enable

peer 4.4.4.4 next-hop-local

ospf 1

area 0.0.0.0

network 3.3.3.3 0.0.0.0

network 10.1.13.0 0.0.0.255

network 10.1.34.0 0.0.0.255

4、配置AR4

System-view

sysname AR4

interface GigabitEthernet0/0/0

ip address 10.1.24.4 255.255.255.0

interface GigabitEthernet0/0/1

ip address 10.1.34.4 255.255.255.0

interface LoopBack0

ip address 4.4.4.4 255.255.255.255

interface LoopBack1

ip address 10.1.100.4 255.255.255.255

bgp 200

peer 2.2.2.2 as-number 200

peer 2.2.2.2 connect-interface LoopBack0

peer 3.3.3.3 as-number 200

peer 3.3.3.3 connect-interface LoopBack0

ipv4-family unicast

undo synchronization

network 10.1.100.4 255.255.255.255

peer 2.2.2.2 enable

peer 2.2.2.2 next-hop-local

peer 3.3.3.3 enable

peer 3.3.3.3 next-hop-local

ospf 1

area 0.0.0.0

network 4.4.4.4 0.0.0.0

network 10.1.24.0 0.0.0.255

network 10.1.34.0 0.0.0.255

四、验证结果

(一)观察完成以上配置后的结果:

1、从AR2上查看BGP邻居关系及BGP路由表,如下图:

从上图看出,到达目标AR1的10.1.100.2有2条路由,下一跳是3.3.3.3为最优路由,local prefrence的值为100;下一跳是10.1.12.1为次优路由,local prefrence的值为2(是我们通过路由策略route-policy修改AR2与AR1邻居关系中的出入流量的local prefrence值为2后,降低了优先级)

2、跟踪从AR2到AR3的路由,是途经的AR4到达的3.3.3.3,而不是走的AR1的10.1.12.1这条,从BGP的优先级看,10.1.12.1是次优路由,如下图:

3、跟踪从AR1运营商服务器10.1.100.2到AR4公司内网服务器10.1.100.4的网络流量路径,是途经AR2的10.1.12.2为主路由,下一跳3.3.3.3是次优路由,如下图:

(二)通过路由策略route-policy修改AR2与AR1邻居关系中的出入流量的local prefrence值为120后,提高优先级,大于100

,修改过程如下图:

使用路由策略route-policy抓取10.1.100.2/32的这条路由,修改local prefrence的值从2改为120,提升BGP路由的优先级。

(三)再对比修改local prefrence值前后的BGP路由表变化

1、当AR2上到达10.1.100.2/32的BGP local prefrence值为2时的路由表,如下图:

2 、当AR2上到达10.1.100.2/32的BGP local prefrence值为120时的路由表,此时再观察AR2上的BGP,就只剩下10.1.12.1,local prefrence为120值的这条路由了,如下图:

(四)查看AR1上BGP路由表,当AR2的local_prefrence值修改为2时,与修改为120时,均无变化,如下图:

复制代码
通过实验验证,修改BGP的local_prefrence值,可以达到修改BGP路由优先级的目的。local_prefrence 只在IBGP对等体进行传播,不会将值传递到AS系统之外。
相关推荐
文牧之1 小时前
PostgreSQL的扩展 pgcrypto
运维·数据库·postgresql
白总Server1 小时前
多智能体系统的中间件架构
linux·运维·服务器·中间件·ribbon·架构·github
qq_429856572 小时前
计算机网络的五层结构(物理层、数据链路层、网络层、传输层、应用层)到底是什么?
网络·计算机网络
2401_867021903 小时前
文件缓冲区(IO与文件 ·III)(linux/C)
linux·运维·服务器·c语言
刘某的Cloud3 小时前
rabbitmq常用命令
linux·运维·分布式·rabbitmq·系统
鸿蒙开发工程师—阿辉3 小时前
一键多环境构建——用 Hvigor 玩转 HarmonyOS Next
ubuntu·华为·harmonyos
NapleC4 小时前
HarmonyOS NEXT:多设备的自由流转
华为·harmonyos
悄悄敲敲敲4 小时前
Linux:进程间通信->命名管道
linux·运维·服务器
io无心4 小时前
Docker绑定端口报错
运维·docker·容器
悄悄敲敲敲6 小时前
Linux:进程间通信->共享内存
linux·运维·服务器