欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

理解BGP协议同步规则

程序员文章站 2022-03-24 20:33:45
理解BGP协议同步规则...

一.理解bgp同步及其基本需求

1.bgp同步规则的定义:

在bgp同步打开的情况下,一个bgp路由器不会把那些通过ibgp邻居学到的bgp路由通告给自己的ebgp邻居;除非自己的igb路由表中存在这些路由,才可以向ebgp路由器通告.

2.bgp同步规则的目的:

防止一个as(不是所有的路由器都运行bgp)内部出现路由黑洞,即向外部通告了一个本as不可达的虚假的路由.

bgp同步规则的拓扑示意

理解BGP协议同步规则

3.bgp同步规则的基本需求

如果一个as内部存在非bgp路由器,那么就出现了bgp和igp的边界,需要在边界路由器将bgp路由发布到igp中,才能保证as所通告到外部的bgp路由在as内部是连通的.实际上是要求bgp路由和igp路由的同步.

4.满足bgp同步规则的基本需求的结果

如果将bgp路由发布到igp中,由于bgp路由主要是来自as外部的路由(来自internet),那么结果是igp路由器要维护数以万计的外部路由,对路由器的cpu和memeory以及as内部的链路带宽的占用将带来巨大的开销.

5.结论

通常bgp协议的运行需要关闭同步.

二.bgp同步的解决方案1.full mesh ibgp解决方案

as内部的所有路由器都运行full mesh ibgp,就可以关闭所有路由器的同步而不影响路由的通告和连通性.

问题:

当as内部路由器数量很多时,需要建立n*(n-1)/2个ibgp会话,带来过度的系统开销,扩展性不好.

full-mesh ibgp 拓扑示意:

15个路由器的as,需要建立15(15-1)/2=105个ibgp会话

理解BGP协议同步规则

2.路由反射器解决方案

as内部的所有路由器都运行bgp,在as内部部署路由反射器,构建hub and spoke的ibgp(会话数为n-1), 然后关闭所有bgp路由器的同步.//本文来自www.jb51.net

问题:

此方案可以使bgp路由器传递ibgp路由到ebgp, 并保证bgp路由的连通性.但是对物理拓扑有很大的限制(要求是星型拓扑)

bgp路由反射器设计拓扑

15个路由器的as,具有冗余的rr方案(33个ibgp会话)

理解BGP协议同步规则

3.bgp联盟解决方案:

as 内部的所有路由器都运行bgp,把一个原始的as基于网络拓扑划分为若干个sub-as(又称联盟as),联盟as之间的bgp邻居叫做联盟ebgp,不需要full mesh bgp会话;在每个联盟as内部运full mesh ibgp或者hub and spoke反射器,然后就可以关闭所有路由器的bgp同步功能.

结论:

bgp联盟结合路由反射器的方式较好的解决了bgp的同步规则带来的需求,是最为有效的解决方案.

bgp联盟拓扑示意图:

理解BGP协议同步规则

三.bgp同步规则的总结

1.在所有的方案中, 既要保证传递bgp路由,还要保证bgp路由的连通性.

2.关闭同步能够实现bgp路由的传递,不一定能保证as内部连通性,除非as内所有路由器都运行bgp才可以保证连通性;否则,仍然需要路由再发布(bgpàigp)

3.最后,在as内部一般需要部署igp来维持as内部网络路径的连通性,以保证as内部的所通告的bgp路由的下一跳的可达性.这样bgp网络就具有更好的灵活性和扩展性.