BGP②

·BGP路径属性详解

为什么要选择路径:根据不同的需要应用在不同的网络当中 

·BGP常用路径属性

Preferred-value,Local_Preference,AS_Path,Origin,MED,Next-Hop,Community,Atomic_Aggregate及aggregator。

·BGP路径属性

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

 

·路径属性分类

·公认属性

·公认必遵属性

·公认自由决定属性

·可选属性

·可选传递的

·可选非传递的

路径属性分类

公认属性

公认必遵

所有的BGP实现必须都能识别,且在Update报文中必须携带。

Origin

AS_Path

公认自决

所有的BGP实现都必须都能识别,但不压迫求必须包含在Update报文中。

Local_Preference

Atomic_Aggregate

可选属性

可选传递

设备可以不支持该属性,但即使不支持,也应当接收包含该属性的路由并传递给其他对等体。

Community

Aggregator

可选非传递

设备可以不支持该属性,不是别的BGP进程忽略包含这个属性的路由更新,并且不传递给其他BGP对等体。

MED

Originator_ID

Cluster_list

*pre_value

 

Preferred-Value

·取值范围:0-65535 该值越大,则路由越优先。

·Preferred-Value只能在路由器本地配置,而且只影响本设备的路由优选。该属性不会传播给任何BGP对等体。

·路由器本地始发的BGP路由默认的Preferred-Value为0,从其他BGP对等体学习到的路由默认Preferred-Value也为0。

 

Local_Preference

·也即本地优先级属性,是公认自决属性,用于告诉AS中的路由器,哪条路径是离开AS的首选路径。

·Local_Preference属性值越大则BGP路由越优。缺省的Local_Preference值为100.

·该属性只能被传递给IBGP对等体,而不能传递给EBGP对等体。

 

Local_Preference注意事项

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

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

·使用bgp default local-preference命令修改缺省Local_Preference值,该值缺省为100.

·路由器在向其EBGP对等体发送路由更新时,不能携带Local_Preference属性,但在对方接收路由之后,会在本地为这条路由赋一个缺省Local_Preference值(100),然后再将路由传递给自己的IBGP对等体。

·本地使用network命令引入及重发布引入的路由,Local_Preference为缺省值100,并能在AS内向其他IBGP对等体传递,传递过程中除非受路由策略影响,否则Local_Preference不变。

AS_Path

·该属性为公认必遵属性,是前往目标网络的路由经过的AS号列表;

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

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

 

AS_Path重要作用之一便是影响BGP路由的优选

BGP各种路径属性是什么 bgp路径属性分类_属性值

Origin

·该属性为公认必遵属性,它标识了BGP路由的起源。如下表所示,根据路由被引入BGP的方式不同,存在三种类型的Origin。

·当去往同一个目的地存在多条不同Origin属性的路由时,在其他条件都相同的情况下,BGP将按如Origin的下顺序优选路由:IGP>EGP>Incomplete

BGP各种路径属性是什么 bgp路径属性分类_优先级_02

MED

·MED是可选非传递属性,是一种度量值,用于向外部对等体指出进入本AS的首选路径,即当进入本AS的入口有多个时,AS可以使用MED动态的影响其他AS选择进入的路径。

·MED属性值越小则BGP路由越优。

·MED主要用于在AS之间影响BGP的选路。MED被传递给EBGP对等体后,对等体在其AS内传递路由时,携带该MED值,但将路由传递给其EBGP对等体时,缺省不会携带MED属性。

 

关于MED的一些注意事项

·缺省情况下,路由器只比较来自同一相邻AS的BGP路由的MED值,也就是说如果去往同一个目的地的两条路由来自不同的相邻AS,则不进行MED值的比较。

·一台BGP路由器将路由通告给EBGP对等体时,是否携带MED属性,需要根据以下条件进行判断(不对EBGP对等体使用策略的情况下):

·如果该BGP路由是本地始发(本地通过network或import-route命令引入)的,则缺省携带MED属性发送给EBGP对等体。

·如果该BGP路由是从其他BGP对等体学习过来的,那么将该路由通告给EBGP对等体时不携带MED。

·在IBGP对等体之间传递路由时,MED值会被保留并传递,除非部署了策略,否则MED值在传递过程中不发生改变也不会丢失。

MED的默认操作

·如果路由器通过IGP学习到一条路由,并通过network或import-route的方式将路由引入BGP,产生的BGP路由的MED值继承路由在IGP中的metric。

·如果路由器将本地直连/静态路由通过network或import-route的方式引入BGP,那么这条BGP路由的MED为0,因为直连/静态路由cost为0。

 

·如果路由器通过BGP学习到其他对等体传递过来的一条路由,那么将路由更新给自己的EBGP对等体时,默认是不携带MED的。这就是所谓的:“MED不会跨AS传递”。例如在上图中,R2将携带MED属性的BGP路由传递给R3,则R3将该路由传递给R4时,不会携带MED。

·可以使用default med命令修改缺省的MED值,default med命令只对本设备上用import-route命令引入的路由和BGP的聚合路由生效。

 

Next_Hop

·该属性是一个公认必遵属性,用于指定到达目标网络的下一跳地址。

·当路由器学习到BGP路由后,需对BGP路由的Next_Hop属性值进行检查,该属性值(IP地址)必须在本地路由可达,如果不可达,则这条BGP路由不可用。

·在EBGP及IBGP对等体的场景中,Next_Hop的缺省操作是存在差异的。

 

Next_Hop的缺省操作

·路由器将BGP路由通告给自己的EBGP对等体,将该路由的Next_Hop设置为自己的更新源IP地址。

 

BGP各种路径属性是什么 bgp路径属性分类_匹配模式_03

BGP路由优选规则概览

BGP各种路径属性是什么 bgp路径属性分类_匹配模式_04

BGP各种路径属性是什么 bgp路径属性分类_BGP各种路径属性是什么_05

关于BGP路径属性的补充

 

 

BGP的路径属性

类型:公认强制、公认必遵

origin、AS_path、Next_hop

当bgp路由器使用update通告路由更新时必须携带的路径属性

 

公认自决定

local_preference

当bgp路由器使用update通告路由更新时不要求必须携带的路径属性

 

可选传递

如果bgp路由器不识别该属性,接受该属性,并且向其他对等体通告时必须携带

 

可选非传递

MED

如果bgp路由器不识别该属性,忽略该更新也不向其他对等体通告

 

讲解常见属性:

preferred_value:华为私有属性,可理解为权重,0-65535,值越大优先级越高,并且只在本地有效,不传递给对等体,默认为0

 

local_preference本地优先级:只能在IBGP对等体之间传递,通告给EBGP时不携带,值越大越优,取值范围0-232,默认为100

 

origin

通过network方式引入bgp的路由,Ogn会显示i

(在任意路由器上操作import-route direct,观察其他路由器的bgp路由表,Ogn会显示?

 

MED

用于向外部对等体指出进入本AS的首选路径,

即当进入本AS的入口有多个时,AS可以使用MED动态地影响其他AS选择进入的路径

 

 

 

 

重点:

BGP的路由优选规则

11条规则,从上到下匹配

 

配置:([R7]dis bgp routing-table 1.1.1.1配置完成后可以查看因为什么属性优选)

  1. 修改preferred_value

[R7]bgp 300

[R7]peer 6.6.6.6 preferred-value 2000

 

  1. 修改local_preference

[R6]ip ip-prefix 1 permit 1.1.1.1 32

[R6]route-policy huawei permit node 10

Info: New Sequence of this List.

[R6-route-policy]if-match ip-prefix 1

[R6-route-policy]apply local-preference 200

[R6]bgp 300

[R6-bgp]peer 7.7.7.7 route-policy huawei export

或者直接

[R6-bgp]default local-preference 3000

 

  1. 修改本地始发的

演示在同一个AS里,R1宣告一个lo口,R2可以学到,R2自己宣告一个一样的,查看R2优选了自己本地的路由条目

 

  1. 修改AS_path

bestroute as-path-ignore:选路由时不比较as_path值

route-policy huawei permit node 10

 if-match acl 2000

 apply as-path 200 additive

#

route-policy huawei permit node 1000

peer 5.5.5.5 route-policy huawei import

 

  1. 修改origin

在R5上network环回口

在R6上创建一个环回口ip地址和R5一样,然后import

查看R7的bgp路由表

 

  1. 修改MED

[R5]route-policy huawei permit node 10

Info: New Sequence of this List.

[R5-route-policy]apply cost 100

[R5-bgp]peer 45.0.0.1 route-policy huawei export

 

 

 

路由策略Route-policy

Route-policy是一个非常重要的基础性策略工具。你可以把它想象成一个拥有多个节点(node)的列表(这些node按编号大小进行排序)。在每个节点中,可以定义条件语句及执行语句,这就有点像程序设计里的if-then语句

 

注意:默认情况下,所有未匹配的路由将被拒绝通过route-policy。如果Route-Policy中定义了一个以上的节点,则各节点中至少应该有一个节点的匹配模式是permit

 

关于路由策略的配置

  1. 创建acl 2000
  2. route-policy RP permit node 10    //格式:route-policy name { permit | deny } node node

if-match acl 2000   //if-match 子句用来定义一些匹配条件。 Route-Policy 的每一个节点可以含有多个 if-match 子句,也可以不含 if-match 子句。如果某个 permit 节点没有配置任何 if-match 子句,则该节点匹配所有的路由

apply     //apply 子句用来指定动作。路由通过 Route-Policy 过滤时,系统按照 apply 子句指定的动作对路由信息的一些属性进行设置。 Route-Policy 的每一个节点可以含有多个 apply 子句,也可以不含 apply 子句。如果只需要过滤路由,不需要设置路由的属性,则不使用 apply 子句

 

匹配规则:路由匹配 Route-Policy 时遵循以下两个规则: 1 ) 顺序匹配:在匹配过程中,系统按节点号从小到大的顺序依次检查各个表项,因此在指定节点号时,要注意符合期望的匹配顺序。 2 ) 唯一匹配: Route-Policy 各节点号之间是“或”的关系,只要通过一个节点的匹配,就认为通过该过滤器,不再进行其它节点的匹配

 

匹配模式:节点的匹配模式有两种: permit 和 deny 。 1 ) permit 指定节点的匹配模式为允许。当路由项通过该节点的过滤后,将执行该节点的 apply 子句,不进入下一个节点;如果路由项没有通过该节点过滤,将进入下一个节点继续匹配。 2 ) deny 指定节点的匹配模式为拒绝。这时 apply 子句不会被执行。当路由项满足该节点的所有 if-match 子句时,将被拒绝通过该节点,不进入下一个节点;如果路由项不满足该节点的 if-match 子句,将进入下一个节点继续匹配

 

peer x.x.x.x route-policy XX import/export  //结合bgp选路

 

( •̀ ω •́ )实验

BGP各种路径属性是什么 bgp路径属性分类_优先级_06