BGP

  • BGP路径选择概述
  • 路径属性
  • 路径属性分类
  • BGP路由优选规则
  • BGP选路原则
  • 实验


BGP路径选择概述

●当BGP设备学习到去往同一个目的网络的多条BGP路由(路径)时,设备将这些路由都装载到BGP路由表,并在这些条目中进行路由优选,最终决策出最优( Best )的路由,将该BGP路由加载到全局路由表中,作为数据转发的依据。

●当存在多路径时, BGP只会将其选择出来的最优路由通告给其他对等体。

●BGP定义了一系列路由优选规则,从而使得设备能够在多条路由中选择出最优的路由。BGP在选择路由时严格按照先后顺序比较路由的属性,如果通过当前的属性就可以选出最优路由, BGP将不再进行后面的比较。

●BGP的选路规则与BGP路径属性及路由策略息息相关,它们使得BGP拥有了强大的路由操控能力。

路径属性

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

路径属性分类

●公认必遵属性:所有的BGP的update消息都要包含该属性

AS路径( AS-path)
下一一跳(next-hop)
起源(Origin)

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

本地优先级( local preferent)

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

==团体属性( community) ==

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

MED

MetalLB BGP模式 bgp multipath_静态路由

BGP路由优选规则

1.优选具有最大Preferred-Value的路由

2.优选具有最大Local_ Preference的路由

3.优选起源于本地的路L

4.优选AS_ Path最短的路由

5.Origin ( IGP > EGP > Incomplete )

6.优选MED最小的路由

7.优选EBGP对等体所通告的路由

8.优选到Next_ Hop的IGP度量值最小的路由

9.BGP路由负载分担

10.优选Cluster_ List 最短的路由

11.优选Router-ID最小的BGP对等体发来的路由

12.优选Peer-IP地址最小的对等体发来的路由
                        其中2.4.6是最常用的

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较小的路由

10.EBGP路由优于IBGP路由

11.BGP优先选择到BGP^下一-跳的IGP度量值最低的路径

当以上全部相同,则为等价路由,可以负载分担(注意:AS_Path必须一致,当负载分担时,以下3条原则无效)
12.比较Cluster list长度,短者优先

13.比较0riginator_ ID (如果没有0riginator_ ID, 则用Router_ ID比较),选择数值较小的路径。

14.比较对等体的IP地址,选择IP地址数值最小的路径。

根据local-prefernce控制选路 (越大越优)
●为公认自决属性,用于告诉AS中的路由器,哪条路径是离开AS的首选路径

●Local_ Preference 属性只能在IBGP对等体间传递( 除非做了策略否则Local_ Preference值 在IBGP对等体间传递过程中不会丢失)而不能在EBGP对等体间传递,如果在EBGP对等体间收到的路由的路径属性中携带了Local_Preference, 则会触发Noti facation 报文,造成会话中断;

●但是可以在AS边界路由器上使用Import方向的策略来修改Local_Preference属性值。也就是在收到路由之后,在本地为路由赋予Local_ Preference。
命令

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

使用AS-PATH属性控制选路(越少越优)
●为公认必遵属性,是前往目标网络的路由经过的AS号列表

●作用:确保路由在EBGP对等体之间传递无环;另外也作为路由优选的衡量标准之一

●路由在被通告给EBGP对等体时,路由器会在该路由的AS__Path中追加上本地的AS号;路由被通告给IBGP对等体时,AS-path不会发生改变

●使用route-policy修改BGP路由的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属性

●使用route-policy修改BGP路由的AS_ Path时,可以在EBGP对等体之间改变EBGP路由的AS_ Path属性,从而影响BGP路由的优选。在华为路由器上,在IBGP对等体之间,也可以使用route-policy修改BGP路由的AS_ Path。无论何种场景,改变BGP路由的AS_ Path都必须十分谨慎,建议跟_上-一个经过的AS号保持一 致。

●Bestroute as-path-ignore命 令
用来配置BGP在选择最优路由时忽略AS路径属性。配置该命令后,BGP将不比较AS路径的长度。缺省情况下,长度更小者优。

实验

MetalLB BGP模式 bgp multipath_MetalLB BGP模式_02


R1

// 配置IP地址
[R1]int g0/0/0
[R1-GigabitEthernet0/0/0]ip add	
[R1-GigabitEthernet0/0/0]ip address 10.0.0.1 24
[R1-GigabitEthernet0/0/0]int g0/0/1
[R1-GigabitEthernet0/0/1]ip address 20.0.0.1 24
//配置环路地址
[R1-GigabitEthernet0/0/1]int loo 0
[R1-LoopBack0]ip add	
[R1-LoopBack0]ip address 1.1.1.1 32
//配置BGP
[R1]bgp 100
[R1-bgp]pe	
[R1-bgp]peer 2.2.2.2 pe	
[R1-bgp]peer 2.2.2.2 as	
[R1-bgp]peer 2.2.2.2 as-number 200
[R1-bgp]pe	
[R1-bgp]peer con	
[R1-bgp]peer 2.2.2.2 con	
[R1-bgp]peer 2.2.2.2 connect-interface l	
[R1-bgp]peer 2.2.2.2 connect-interface LoopBack 0
[R1-bgp]pe	
[R1-bgp]pe	
[R1-bgp]peer 3.3.3.3 as	
[R1-bgp]peer 3.3.3.3 as-number 200
[R1-bgp]pe	
[R1-bgp]peer 3.3.3.3 con	
[R1-bgp]peer 3.3.3.3 connect-interface l	
[R1-bgp]peer 3.3.3.3 connect-interface LoopBack 0
[R1-bgp]pe	
[R1-bgp]peer 2.2.2.2 e	
[R1-bgp]peer 2.2.2.2 ebgp-max-hop 2
[R1-bgp]pe	
[R1-bgp]peer 3.3.3.3 e	
[R1-bgp]peer 3.3.3.3 ebgp-max-hop 2
//配置静态路由
[R1]ip route-static 2.2.2.2 32 10.0.0.2 
[R1]ip rou	
[R1]ip route
[R1]ip route-static 3.3.3.3 32 20.0.0.2
//宣告BGP网段
[R1]bgp 100
[R1-bgp]net	
[R1-bgp]network 1.1.1.1 32
[R1-bgp]net	
[R1-bgp]network 2.2.2.2 32
[R1-bgp]net	
[R1-bgp]network 3.3.3.3 32

R2

//配置IP地址
[R2]int g0/0/0
[R2-GigabitEthernet0/0/0]ip add 10.0.0.2 24
[R2-GigabitEthernet0/0/0]int g0/0/1
[R2-GigabitEthernet0/0/1]ip add 30.0.0.2 24
//配置环路地址
[R2-GigabitEthernet0/0/1]int loo 0
[R2-LoopBack0]ip add 2.2.2.2 32
//宣告ospf
[R2-ospf-1]area 0
[R2-ospf-1-area-0.0.0.0]net	
[R2-ospf-1-area-0.0.0.0]network 10.0.0.0 0.0.0.255
[R2-ospf-1-area-0.0.0.0]net	
[R2-ospf-1-area-0.0.0.0]network 30.0.0.0 0.0.0.255
[R2-ospf-1-area-0.0.0.0]net	
[R2-ospf-1-area-0.0.0.0]network 2.2.2.2 0.0.0.0
//配置BGP
[R2-bgp]peer 1.1.1.1 as	
[R2-bgp]peer 1.1.1.1 as-number 100
[R2-bgp]pe	
[R2-bgp]peer 1.1.1.1 con	
[R2-bgp]peer 1.1.1.1 connect-interface l	
[R2-bgp]peer 1.1.1.1 connect-interface LoopBack 0
[R2-bgp]pe	
[R2-bgp]peer 4.4.4.4 as	
[R2-bgp]peer 4.4.4.4 as-number 200
[R2-bgp]pe	
[R2-bgp]peer 4.4.4.4 con	
[R2-bgp]peer 4.4.4.4 connect-interface l	
[R2-bgp]peer 4.4.4.4 connect-interface LoopBack 0
[R2-bgp]pe	
[R2-bgp]peer 3.3.3.3 as	
[R2-bgp]peer 3.3.3.3 as-number 200
[R2-bgp]pe	
[R2-bgp]peer 3.3.3.3 con	
[R2-bgp]peer 3.3.3.3 connect-interface l	
[R2-bgp]peer 3.3.3.3 connect-interface LoopBack 0
[R2-bgp]pe	
[R2-bgp]peer 1.1.1.1 e	
[R2-bgp]peer 1.1.1.1 ebgp-max-hop 2
[R2-bgp]pe	
[R2-bgp]peer 4.4.4.4 next	
[R2-bgp]peer 4.4.4.4 next-hop-l	
[R2-bgp]peer 4.4.4.4 next-hop-local 
//配置静态路由
[R2]ip route-static 1.1.1.1 32 10.0.0.1
//宣告BGP
[R2]bgp 200
[R2-bgp]net	
[R2-bgp]network 2.2.2.2 32
[R2-bgp]net	
[R2-bgp]network 4.4.4.4 32
[R2-bgp]net	
[R2-bgp]network 3.3.3.3 32
[R2-bgp]net	
[R2-bgp]network 1.1.1.1 32

R3

// 配置IP地址
[R3]int g0/0/0
[R3-GigabitEthernet0/0/0]ip add 20.0.0.3 24
[R3-GigabitEthernet0/0/0]int g0/0/1
[R3-GigabitEthernet0/0/1]ip add 40.0.0.3 24
//配置环路地址
R3-GigabitEthernet0/0/1]int loo 0
[R3-LoopBack0]ip add 3.3.3.3 32
//配置ospf
[R3-ospf-1]area 0
[R3-ospf-1-area-0.0.0.0]net	
[R3-ospf-1-area-0.0.0.0]network 20.0.0.0 0.0.0.255
[R3-ospf-1-area-0.0.0.0]net	
[R3-ospf-1-area-0.0.0.0]network 40.0.0.0 0.0.0.255
[R3-ospf-1-area-0.0.0.0]net	
[R3-ospf-1-area-0.0.0.0]network 3.3.3.3 0.0.0.0
//配置BGP
[R3-ospf-1-area-0.0.0.0]bgp 200
[R3-bgp]pe	
[R3-bgp]peer 1.1.1.1 as	
[R3-bgp]peer 1.1.1.1 as-number 100
[R3-bgp]pe	
[R3-bgp]peer 1.1.1.1 con	
[R3-bgp]peer 1.1.1.1 connect-interface l	
[R3-bgp]peer 1.1.1.1 connect-interface LoopBack 0
[R3-bgp]pe	
[R3-bgp]peer 4.4.4.4 as	
[R3-bgp]peer 4.4.4.4 as-number 200
[R3-bgp]pe	
[R3-bgp]peer 4.4.4.4 con	
[R3-bgp]peer 4.4.4.4 connect-interface l	
[R3-bgp]peer 4.4.4.4 connect-interface LoopBack 0
[R3-bgp]pe	
[R3-bgp]peer 2.2.2.2 as	
[R3-bgp]peer 2.2.2.2 as-number 200
[R3-bgp]pe	
[R3-bgp]peer 2.2.2.2 con	
[R3-bgp]peer 2.2.2.2 connect-interface l	
[R3-bgp]peer 2.2.2.2 connect-interface LoopBack 0
[R3-bgp]pe	
[R3-bgp]peer 1.1.1.1 e	
[R3-bgp]peer 1.1.1.1 ebgp-max-hop 2
[R3-bgp]pe	
[R3-bgp]peer 4.4.4.4 next	
[R3-bgp]peer 4.4.4.4 next-hop-l	
[R3-bgp]peer 4.4.4.4 next-hop-local 
//配置静态路由
[R3]ip rou	
[R3]ip route
[R3]ip route-static 1.1.1.1 32 20.0.0.1
//配置BGP宣告
[R3]bgp 200
[R3-bgp]net	
[R3-bgp]network 3.3.3.3 32
[R3-bgp]net	
[R3-bgp]network 4.4.4.4 32
[R3-bgp]net	
[R3-bgp]network 2.2.2.2 32
[R3-bgp]net	
[R3-bgp]network 1.1.1.1 32

R4

// 配置IP地址
[R4]int g0/0/0
[R4-GigabitEthernet0/0/0]ip add	
[R4-GigabitEthernet0/0/0]ip address 30.0.0.4 24
[R4-GigabitEthernet0/0/0]int g0/0/1
[R4-GigabitEthernet0/0/1]ip address 40.0.0.4 24
[R4-GigabitEthernet0/0/1]int g0/0/2
[R4-GigabitEthernet0/0/2]ip address 50.0.0.4 24
//配置环路地址
[R4-GigabitEthernet0/0/2]int loo0
[R4-LoopBack0]ip add 4.4.4.4 32
//配置ospf
[R4]ospf
[R4-ospf-1]area 0
[R4-ospf-1-area-0.0.0.0]net	
[R4-ospf-1-area-0.0.0.0]network 30.0.0.0 0.0.0.255
[R4-ospf-1-area-0.0.0.0]net	
[R4-ospf-1-area-0.0.0.0]network 40.0.0.0 0.0.0.255
[R4-ospf-1-area-0.0.0.0]net	
[R4-ospf-1-area-0.0.0.0]network 4.4.4.4 0.0.0.0
//配置BGP
[R4-ospf-1-area-0.0.0.0]bgp 200
[R4-bgp]pe	
[R4-bgp]peer 2.2.2.2 as	
[R4-bgp]peer 2.2.2.2 as-number 200
[R4-bgp]pe	
[R4-bgp]peer 2.2.2.2 con	
[R4-bgp]peer 2.2.2.2 connect-interface l	
[R4-bgp]peer 2.2.2.2 connect-interface LoopBack 0
[R4-bgp]pe	
[R4-bgp]peer 3.3.3.3 as	
[R4-bgp]peer 3.3.3.3 as-number 200
[R4-bgp]pe	
[R4-bgp]peer 3.3.3.3 con	
[R4-bgp]peer 3.3.3.3 connect-interface l	
[R4-bgp]peer 3.3.3.3 connect-interface LoopBack 0
[R4-bgp]pe	
[R4-bgp]peer 5.5.5.5 s	
[R4-bgp]peer 5.5.5.5 as	
[R4-bgp]peer 5.5.5.5 as-number 300
[R4-bgp]pe	
[R4-bgp]peer 5.5.5.5 con	
[R4-bgp]peer 5.5.5.5 connect-interface l	
[R4-bgp]peer 5.5.5.5 connect-interface LoopBack 0
[R4-bgp]pe	
[R4-bgp]peer 5.5.5.5 e	
[R4-bgp]peer 5.5.5.5 ebgp-max-hop 2
[R4-bgp]pe	
[R4-bgp]peer 2.2.2.2 next	
[R4-bgp]peer 2.2.2.2 next-hop-l	
[R4-bgp]peer 2.2.2.2 next-hop-local 
[R4-bgp]pe	
[R4-bgp]peer 3.3.3.3 next	
[R4-bgp]peer 3.3.3.3 next-hop-l	
[R4-bgp]peer 3.3.3.3 next-hop-local
//配置静态路由
R4]ip rou	
[R4]ip route
[R4]ip route-static 5.5.5.5 32 50.0.0.5
//配置BGP宣告
[R4]bgp 200
[R4-bgp]net	
[R4-bgp]network 2.2.2.2 32
[R4-bgp]net	
[R4-bgp]network 4.4.4.4 32
[R4-bgp]net	
[R4-bgp]network 3.3.3.3 32
[R4-bgp]net	
[R4-bgp]network 5.5.5.5 32

R5

//配置IP地址
[R5]int g0/0/0
[R5-GigabitEthernet0/0/0]ip add 50.0.0.5 24
//配置环路地址
[R5-GigabitEthernet0/0/0]int loo 0
[R5-LoopBack0]ip add 5.5.5.5 32
//配置BGP
[R5]bgp 300
[R5-bgp]pe	
[R5-bgp]peer 4.4.4.4 as	
[R5-bgp]peer 4.4.4.4 as-number 200
[R5-bgp]pe	
[R5-bgp]peer con	
[R5-bgp]peer 4.4.4.4 con	
[R5-bgp]peer 4.4.4.4 connect-interface l	
[R5-bgp]peer 4.4.4.4 connect-interface LoopBack 0
[R5-bgp]pwe	
[R5-bgp]pe	
[R5-bgp]peer 4.4.4.4 e	
[R5-bgp]peer 4.4.4.4 ebgp-max-hop 2
//配置静态路由
[R5]ip rou	
[R5]ip route-static
[R5]ip route
[R5]ip route-static 4.4.4.4 32 50.0.0.4
//配置BGP宣告
[R5]bgp 300
[R5-bgp]net	
[R5-bgp]network 4.4.4.4 32
[R5-bgp]net	
[R5-bgp]network 5.5.5.5 32

配置路由路径选取

MetalLB BGP模式 bgp multipath_静态路由_03


MetalLB BGP模式 bgp multipath_ospf_04


MetalLB BGP模式 bgp multipath_MetalLB BGP模式_05


MetalLB BGP模式 bgp multipath_IP_06


MetalLB BGP模式 bgp multipath_MetalLB BGP模式_07

MetalLB BGP模式 bgp multipath_MetalLB BGP模式_08


MetalLB BGP模式 bgp multipath_IP_09


MetalLB BGP模式 bgp multipath_IP_10


MetalLB BGP模式 bgp multipath_IP_11