2020年特殊的春节,特殊的寒假。停课不停学,大好时光怎么能浪费呢(其实是闲得蛋疼了)!闲来无事RFC!!!那就看看RFC文档把,了解一下BGP的原理,顺便看看广受业内人士称赞的斑驴。走马观花一波,看到哪里是哪里,毕竟实力有限,很难理解得很透彻。

1. BGP的状态机

    BGP是根据状态机进行运转的,搞清楚了BGP的状态机,对BGP工作原理的理解没有Ⅹ也有Ⅲ Ⅳ了。
    限于篇幅,本文只讨论一切步骤都完美正常执行的情况(即收到的包都是正确的,与peer建立TCP连接一次成功等等)。当然RFC文档种还详细介绍了各种突发状况、各种处理方法等,实在是有点多,下篇文章再完整地叙述吧。

1.1 Idle state

    BGP协议为每一个peer(对等体)即邻居维护一个FSM。在配置BGP路由的时候,会经常见到这两个命令:
    router bgp asn     该命令创建了一个bgp实例,还没有创建peer,FSM还没开始。
    另一个命令:
    neighbor X.X.X.X remote-as asn     neighbor命令执行后,bgp会为其创建一个peer,为其创建相应的FSM并开始运转,初始状态为Idle。
    Idle state不接受任何的TCP连接(比如别的BGP路由器要与其建立TCP连接)。可以认为,在Idle state的前半段,什么事都没干。当FSM捕获到一个ManualStart event或者AutomaticStart event时,开始进入Idle state的后半段。

notes: 
    ManualStart event:当用neighbor指定一个邻居之后,就要跟邻居建立TCP连接;如果ManualStart = TRUE,那么与邻居建立TCP连接的过程就需要另外手动输入命令。(根据自己理解猜测的,不保证完全正确,仅供参考)
    AutomaticStart event:如果AutomaticStart = TRUE,那么与邻居建立TCP连接的过程就可以自动进行,应该是在neighbor命令执行后等待短暂的时间后进行peer的TCP连接。

    捕获到一个ManualStart event或者AutomaticStart event时,Idle state的后半段开始了,后半段做的事主要有:
    (1)初始化BGP peer连接的资源(没咋懂)
    (2)初始化TCP 连接,说白了就是要开始与别的peer建立起TCP连接关系
    (3)监听TCP请求,可能是自己请求与别的peer建立TCP连接,也可能是别的peer请求与自己建立TCP连接关系
    (4)Set ConnectRetryCounter = 0
    (5)Starts the ConnectRetryTimer with the initial value
    (6)FSM开始转换状态,有Idle转为Connect(如果是ManualStart_with_PassiveTcpEstablishment event或者AutomaticStart_with_PassiveTcpEstablishment event则转为Active,这两个状态没有本质区别,先不管)

notes:
    ConnectRetryCounter:表示尝试与peer建立TCP连接的次数,至于到达一定次数会怎么样,文档里我没找到
    ConnectRetryTimer:定时器,即过多久尝试与peer建立TCP连接,RFC里建议的初始值为120s

    注意:Idle state的后半段并不保证TCP连接已经建立完成,即Idle state会进行与peer进行TCP连接这个动作,该TCP连接可以一次成功、可能尝试多次才成功也可能不成功。但是FSM可不等TCP连接建立成功了才转换到Connect state,即在Idle state后半段我发出了建立TCP连接这个指令,就转换到Connect state,不管TCP连接成没成功。

1.2 Connect state

    当Idle state中的各个步骤都可以正确无误地执行后,就进入到了Connect state,在该状态又有其对应的一些事件及操作,让我们......荡起双桨......。
    Connect state在等待着TCP连接成功,如果TCP连接成功了(当然还有可能连接不成功和其他突发事件,这里不叙述),则会执行以下动作:
    (1)停止ConnectRetryTimer计时器
    (2)设置DelayOpenTimer为初始值
    (3)发送一个OPEN msg给peer(如果没设置DelayOpenTimer立马发送,有设置则等到时间到了再发送)
    (4)Sets the HoldTimer to a large value
    (5)改变状态到OpenSent state

notes:
    DelayOpenTimer:又一个定时器,指当与peer成功建立TCP连接后是否要延迟发送OPEN msg
    HoldTimer:指从对端peer收到一个KEEPALIVE/UPDATE msg所需要的最长时间,RFC建议default value为 90 s、large value为 4 min

1.3 OpenSent state

    如果一切正常无error,那么就会从Connect state进入到OpenSent state。OpenSent state在等待着OPEN msg的到来,如果收到一个正确无误的OPEN msg后,则会进行:
    (1)Resets the DelayOpenTimer to zero(有什么用呢)
    (2)sets the BGP ConnectRetryTimer to zero
    (3)发送一个KEEPALIVE msg并启动KeepaliveTimer
    (4)转换状态至OpenConfirm

1.4 OpenConfirm state

    因为已经发送了一个KEEPALIVE msg给对端peer,所以在OpenConfirm state在等待着对端peer发送一个KEEPALIVE/NOTIFICATION msg过来。如果正确地收到了一个KEEPALIVE msg,则:
    (1)重启HoldTimer
    (2)转换状态至Established state

1.5 Established state

    Established state可以说是BGP正常工作的最后一种状态了,进入了该状态BGP peer之间可以进行发送/接收UPDATE/NOTIFICATION/KEEPALIVE msg,也就是可以正常地交换更新网络中的路由信息了。
    若收到一个KEEPALIVE msg则:
    (1)重置HoldTimer定时器
    (2)状态仍是Established state
    若收到一个UPDATE msg,则:
    (1)处理UPDATE msg
    (2)重置HoldTimer定时器
    (3)状态仍是Established state