BGP路径选择、反射器、聚合

BGP路径属性

当一条BGP路由被BGP路由器更新给其对等体时,这条BGP路由会携带多个路径属性值(Path Attributes)一并传递给对等体,BGP的这些路径属性,将影响BGP的路由优选。他们的存在使得BGP的路由策略能力异常强大。

BGP路由优选规则概览

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

2.优选具有最大Local_Preference的路由

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

4.优选AS_Path最短的路由

5.Origin(IGP>EGP>Ilncomplete)

6.优选MED最小的路由

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

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

9.BGP路由负载分担

10.优选Cluster_List最短的路由

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

12.优选Peer-IP地址最小的对等体发来的路由

路径属性分类

  • 公认属性Well-Known
  • 公认必尊属性Well-known mandatory
  • 公认自由决定属性Well-known discretionary
  • 可选属性 Optional
  • 可选传递的 Optional non-transitive
  • 可选非传递的 Optional non-transitive

在这里插入图片描述

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.比较Originator_ID(如果没有Originator_ID,则用Router_ID比较),选择数值较小的路径
14.比较对等体的IP地址选择IP地址数值最小的路径

BGP属性选路配置

共12种方法,这里介绍3种常用方法:

  • 根据local-prefernce控制选路(越大越优)
  • 为公认自由属性,用于告诉AS中的路由器,哪条路径是离开AS的首选路径
  • Local_Preference属性只能在IBGP对等体间传递(除非做策略否则Local_Preference值在IBGP对等体间传递过程中不会丢失),而不能再EBGP对等体间传递,如果在EBGP对等体间收到的路由的路径属性中携带了 Local_Preference,则会触发Notifacation报文,造成会话中断:
  • 但是可以在AS边界路由器上使用Import方向的策略来修改Local_Preference属性值。也就是在收到路由之后,在本地为路由赋予 Local_Preference
[R3]route-policy lop permit node 10
注:创建一个指定的策略 lop名字
[R3-route-policy]apply local-preference  222
注:应用 优先级设置为222
[R3-route-policy]q
[R3]bgp 200
[R3-bgp]peer 4.4.4.4 route-policy lop export 
注:使R3到R4出站方向为export的路由策略,R4配置此策略则为import入站
[R3-bgp]q
[R3]q
<R3>refresh bgp all export
注:刷新
  • 使用AS-PATB属性控制选路(越少越优先)

  • 为公认必遵属性,是前往目标网络的路由经过的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路由的优选。在华为路由器上,在EBGP对等体之间,也可使用route-policy修改BGP路由的As_path。无论何种场景,改变BGP路由的As_path都必须十分谨慎,建议跟上一个经过的AS号保持一致。

  • Bestroute as-path-ignore命令
    用来配置BGP在选择最优路由时忽略AS路径属性。配置该命令后,BGP将不比较AS路径的长度,越小越优

[R2]route-policy as permit node 10
[R2-route-policy]apply as-path 123 123 additive
注:在已有AS-path基础上追加
[R2-route-policy]q
[R2]bgp 200
[R2-bgp]peer 4.4.4.4 route-policy as export  
[R2-bgp]q
[R2]q
<R2>refresh bgp all export
  • 通过MED属性控制选路(越小越优)

  • 为可选非传递属性,是一种度量值

  • 一般情况下,BGP设备只比较来自同一AS(不同对等体)的路由的MED值。可以通过配置命令来允许BGP比较来自不同AS的路由的MED属性值

  • 执行compare-different-as-med命令后,系统将比较来自不同AS来自不同AS中的对等体的路由的MED值。

[R2]route-policy med permit node 10 
[R2-route-policy]apply cost + 500 
[R2-route-policy]q
[R2]bgp 200
[R2-bgp]peer 1.1.1.1 route-policy med export
[R2-bgp]q
[R2]q
<R2>refresh bgp all export
<R2>sys
[R2]dis bgp routing-table
[R2]dis bgp routing-table
  • 多网段情况下只匹配某一网段选路
  • Origin属于公有必遵,用来定义路径信息的来源,其作用是标记一条路由时如何成为BGP路由的,EBGP邻居之间起作用。
  • 它有三种属性:①IGP(i):优先级最高,②EGP(e):优先级次之,③Incomplete(?):优先级最低
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 20


bgp 100
network 100.0.1.0 24
peer 10.1.13.3 as-number 345
peer 10.1.13.3 route-policy RP export

BGP反射器

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


RR向IBGP邻居发布路由规则如下:

  • 从非客户端学到的路由,发布给所有客户端。
  • 从客户端学到的路由,发布给所有非客户端和客户端(发起此路由的客户端除外)。
  • 从EBGP对等体学到的路由,发布给所有的非客户端和客户端。
[R2]bgp 100
[R2-bgp ] router-id 2.2.2.2
[R2-bgp]peer 1.1.1.1 as-number 100
[R2-bgp]peer 1.1.1.1 connect-interface LoopBack 0
[R2-bgp]peer 3.3.3.3 as-number 100
[R2-bgp]peer 3.3.3.3 connect-interface LoopBack 0
[R2-bgp]peer 4.4.4.4 as-number 100
[R2-bgp]peer 4.4.4.4 connect-interface LoopBack 0
[R2-bgp]peer 5.5.5.5 as-number 100
[R2-bgp]peer 5.5.5.5 connect-interface LoopBack 0
[R2-bgp]reflector cluster-id 2
配置路由反射器的集群ID
[R2-bgp]peer 3.3.3.3 reflect-client
指定客户端

BGP路由聚合(汇总)

方案一:创建静态汇总路由

[R7]ip route-static 192.168.0.0 255.255.255.0 Nullo
[R7-bgp]network 192.168.0.0 255.255.255.0
注:将这个聚合的路由通告出去
将聚合的路由通告出去,因为手动汇总的这个192.168.0.0在路由表中是不存在的,要把它加入到Nullo里才能在bgp进程里用上面的network来通告这条路由


12.0.0.0  00   001100
13.0.0.0  00   001101
24.0.0.0  00   011000
34.0.0.0  00   100010
45.0.0.0  00   101101

方案二:

[R7-bgp]aggregate 192.168.0.0 255.255.255.0 detail-suppressed as-set

注:配置手动路由聚合用aggregate,detail-suppressed是抑制明细路由的通告,增加as-set关键字后,该汇总路由将继承明细路由的路径属性,其中对明细路由AS_path属性可以起到汇总路由防环作用

猜你喜欢

转载自blog.csdn.net/weixin_53496398/article/details/112738794