一、BGP的6种状态机
在BGP对等体的报文交互过程中存在6种状态机:空闲(Idle)、连接(Connect)、活跃(Active)、Open报文已发送(OpenSent)、Open报文已确认(OpenConfirm)和连接已建立(Established)。这6种状态机的转换过程如下图所示。其中,在BGP对等体建立的过程中,使用了Idle、Active和Established3种状态机。但要注意的是,BGP是一个应用层协议,而且使用的是TCP传输层协议,所以在BGP对等体连接建立前先要在对等体间建立TCP连接。
二、状态机之间的转换过程
- Idle状态是BGP的初始状态(使能了BGP功能但未指定邻居)。在Idle状态下,BGP拒绝邻居发送的连接请求。只有在收到本设备的Start事件(指定了邻居)后,BGP才开始尝试和其他BGP对等体进行TCP连接,并转换至Connect(连接)状态。
Start事件是由一个操作者配置一个BGP过程,或者重置一个已经存在的过程,或者路由器软件重置BGP过程引发的。任何状态种收到Notification报文或TCP拆链通知等Error(错误)事件后,BGP都会转换至Idle状态。
- 在Connect状态下,BGP启动连接重传定时器(Connect Retry),等待TCP完成连接。
- 如果TCP连接成功,那么本地BGP向BGP对等体发送Open报文,并转换至OpenSent状态。
- 如果TCP连接失败,那么本地BGP转换至Active状态。
- 如果连接重传定时器超时后本地BGP仍没有收到BGP对等体的响应,那么本地BGP会继续尝试和其他BGP对等体进行TCP连接,停留在Connect状态。
- 在Active状态下,本地BGP总是在试图建立TCP连接。(Connect是等待对方,Active是主动请求)
- 如果TCP连接成功,那么本地BGP向BGP对等体发送Open报文,关闭连接重传定时器,并转换至Opensent状态。
- 如果TCP连接失败,那么本地BGP停留在Active状态。
- 如果连接重传定时器超时后本地BGP仍没有收到BGP对等体的响应,那么本地BGP转换至Connect状态。
- 在OpenSent状态下,本地BGP等待对等体的Open报文,并对收到的Open报文中的AS号、版本号、认证码等进行检查。
- 如果收到的Open报文正确,那么本地BGP向BGP对等体发送Keepalive报文,并转换至OpenConfirm状态。
- 如果发现收到的Open报文有错误,那么本地BGP向BGP对等体发送Notification报文给对等体,并转换至Idle状态。
- 在OpenConfirm状态下,本地BGP等待来自BGP对等体的Keepalive或Notification报文。如果收到Keepalive报文,则转换至Established状态;如果收到Notification报文,则转换至Idle状态。
- 在Established状态下,本地BGP可以和BGP对等体交换Update、Keepalive、Route-refresh报文和Notification报文。
- 如果收到正确的Update或Keepalive报文,那么本地BGP就认为对端处于正常运行状态,将保持BGP连接。
- 如果收到错误的Update或Keepalive报文,那么本地BGP发送Notification报文通知对端,并转换至Idle状态。
- Route-refresh报文不会改变BGP状态。
- 如果收到Notification报文,那么本地BGP转换至Idle状态。
- 如果收到TCP拆链通知,那么本地BGP断开连接,转换至Idle状态。
在建立EBGP邻居关系的时候,使用物理口更好还是环回口更好?
- 环回口好,物理口建立TCP会话有两个,环回口口建立只需要一个TCP的会话
- 物理口建立,那么R2学习到R1的路由条目数会是环回口建立的条目数两倍
- 物理口建立,当主链路故障的时候,备用链路的EBGP路由才会放入到路由表,放入到路由表是需要时间的
建立EBGP邻居的时候,使用环回口建立要配置EBGP多跳,是因为TTL不够吗?
不是TTL不够,是因为EBGP建立邻居的时候需要直连检测,BGP的状态机可以到达open confirm状态,因为KA报文需要做直连检测。
解决多跳建立EBGP除了使用EBGP多跳以外还有其他的解决方法吗?可以配置valid-ttl-hops
以上就是本章的全部内容了,感谢大家的浏览观看!文章中如有错误或疑问可联系博主删除或更改,文章部分内容源自教材《华为路由器学习指南》感兴趣可购买相关书籍浏览。