国内服务器
亚洲服务器
欧洲服务器
北美洲服务器
南美洲服务器
大洋洲服务器
非洲服务器

首页>>IDC资讯

边界网关协议BGP中同步问题浅析

发表时间:2023-02-03 07:55:38

边界网关协议BGP中同步问题浅析

  1.BGP路由同步概念

BGP是自治系统间的路由协议。BGP交换的网络可达性信息提供了足够的信息来检测路由回路并根据性能优先和策略束缚对路由进行决策。特别地,BGP交换包括全部ASpath的网络可达性信息,依照配置信息履行路由策略。

BGP协议规定:

一个运行BGP协议的路由器不会把从内部对等体(IBGP邻居)得知的路由信息通告给外部对等体(EBGP邻居),除非该路由信息也能通过IGP得知。若BGP路由器能通过IGP得知该路由信息,则可认为路由能在AS之间传播,内部通达已有保证。

首先,RTB通过EBGP邻居关系,取得了去往AS100的路由信息,例如,去往AS100中的10.1.1.1/24,RTB会把这样的路由信息通告给RTE,RTE收到从RTB通告来的去往自治系统AS100的路由信息10.1.1.1/24。对RTE来讲,它在斟酌是否是把这样的路由信息通告给它的EBGP邻居RTF时,就需要斟酌同步问题。这里的同步是指:RTE如果能通过IGP(内部网关协议,如OSPF协议)取得去往10.1.1.1/24的路由,我们就认为EGP(外部网关协议,如BGP协议)和IGP同步。在同步情况下,RTE可以将路由信息10.1.1.1/24通告给RTF。否则,不能通告。

通过上面的叙述,相信大家应当知道甚么是BGP同步了。那末BGP的设计者们为啥要做这样一个规定呢?为啥要引入BGP同步的概念呢?

下面我们来讲说BGP同步存在的重要性和它所解决的关键问题。

  2.BGP路由同步的重要性

仍然用上面的例子来解释,如果RTE不斟酌同步问题,直接将路由信息10.1.1.1/24通告给RTF,那末RTF的路由表中就会记录一条去往10.1.1.1/24的路由信息,下一跳是指向RTE的。这样问题就会出现:RTF有一去往10.1.1.1/24的数据包,RTF通过查看路由表,把这一数据包转发给RTE。如果没有同步,RTE的路由表中也会有去往10.1.1.1/24的表项,但是这一表项的下一跳是直接指向RTA的S0接口的(这里的缘由参见BGP的下一跳属性)。在不同步的情况下,RTE是没法直接去往此路由的下一跳的(由于路径中途的路由器RTD、RTC都没有去往10.1.1.1/24的路由)。这里有个概念叫下一跳不可达,就是指这类情况。

那末,讲到这里,聪明的读者会不会明白了呢?BGP强调同步的缘由就是要保证下一跳可达。用上面的例子来讲,就是RTE在斟酌把去往10.1.1.1/24的路由信息通告给RTF时,就需要斟酌它去往10.1.1.1/24的下一跳是否是可达(这里的下一跳就是指RTA的S0接口,此接口是AS200和AS300去往AS100的入口)。如果这个入口都不可达,更不要说访问其内部了。所以下一跳是否是可达的问题是一个关键性问题,BGP强调同步,就是要求RTE所在自治系统的IGP协议能够实现下一跳可达。如果IGP找到了去往下一跳的路由,那末RTE就得到了两个去往10.1.1.1/24的路由。一个是:通过BGP取得的,这个路由的下一跳不可达。另外一个是:通过IGP取得的,这一个下一跳可达(关于为啥BGP取得的路由下一跳不可达,而IGP取得的路由下一跳可达,这个问题需要大家对BGP的下一跳属性做进一步了解,这里不再叙述)。

3.BGP的路由可达和不可达问题

关于下一跳可达和不可达问题,下面做进一步说明。仍然用上面的例子。由于在BGP系统中的下一跳是以自治系统为单位的(这一点在BGP的下一跳属性中,有详细叙述)。这样,就会有这样的问题存在,RTE的路由表中有去往10.1.1.1/24的路由,但是下一跳却在很远的地方,以致于下一跳不可达。但是对IGP来讲就不会有这样的问题出现。这都是由于各自下一跳的定义不同酿成的(关于下一跳的定义,我们就不讨论了,BGP的设计者这样定义,也是经过综合斟酌和选择的)。既然BGP发现的路由有下一跳不可达的问题存在,我们就要解决这样的问题,BGP同步就是解决的方法。

固然同步是可以选择的。在华为3Com3Com路由器上,同步是可以被取消的。取消了同步以后,路由器通告路由时,就不再斟酌同步问题了,直接将自己的路由信息通告给EBGP邻居。但是这样就会出现下一跳不可达的问题。所以,我们在取消同步之前就要斟酌好如何处理可能出现的下一跳不可达问题。对上面例子中的情况来讲:RTE所在的自治系统里所有的路由器都要知道如何去往RTA的S0接口。只要满足了下一跳可达,取消同步也是可以的。

取消同步以后,满足下一跳可达的方法有很多,需要视具体网络拓扑情况而定。就上面例子来讲,可以由RTB将BGP路由引入IGP中,固然这样的做法一般不采取,应为BGP的路由信息量很大,对IGP来讲负担太重。另外,我们可以在RTC、RTD、RTE上增加静态路由,同时在RTA上也增加静态路由。这类办法看起来很笨,也不是最理想的办法。最后,BGP可以通过命令来强迫修改下一跳,在RTE上将去往10.1.1.1/24的下一跳强迫修改成RTE本身的接口,同时,需要RTD、RTC的路由表中有去往10.1.1.1/24的路由。这也不是最理想的解决方法。由于可能或需要借助于静态路由。其实,对上面例子的拓扑结构,主要是:IBGP邻居不是直接的连接关系,而是TCP连接。BGP路由协议在这样的拓扑结构上的下一跳可达问题,一直没有理想的解决方案。如果这类情况的网络不是很复杂,或可以委曲解决的(上面已介绍了几种解决方法)。但是一旦网络复杂了,解决起来就很困难了。所以,在网络设计时,一定要注意避开这类情况。IBGP邻居尽可能直接连接。这个问题的完全解决是在BGP和组网联手以后的事情。以后有机会大家再学习!

4、小结

BGP下一跳属性规定:BGP路由的下一跳是以自治系统为单位的。这样就引出了BGP路由下一跳不可达的问题,为解决路由下一跳不可达的问题,BGP协议引入了同步概念。同步也是可以通过命令取消的,只要能保证路由的下一跳可达,就能够了。

上一篇 下一篇
最新文章

如何提高云服务器的安全系数

香港独立IP空间有什么优势

香港空间影响百度收录吗

为啥要租用美国VPS

VPS的缺点有哪些

香港vps作用在哪里

VPS的优点有哪些

外贸网站为啥选择美国vps

VPS能建多少个网站

VPS要如何选择位置

相关文章

东莞sdwan运营商服务介绍,sdwan公司推荐

通过Windows Server实现安全的远程桌面服务与访问

如何满足IDC建设预算和时间表?

智能云硬盘怎样用 本地硬盘和云硬盘的差异

日本服务器安全性分析与最好实践

ProwHost-$9.99/月/1G内存40GB 硬盘/2TB流量@1Gbps端口/KVM/日本/新加坡/韩国/美国/欧洲等

国外vps云服务器数据丢失的有哪些原因

云主机与普通服务器有哪些不同

美国哪里买服务器低价?探访最好租赁地点

​网页服务器无响应问题有哪些?怎么解决?

X

截屏,微信识别二维码

微信号:muhuanidc

(点击微信号复制,添加好友)

打开微信

微信号已复制,请打开微信添加咨询详情!