美文网首页网络大咖
BGP配置BFD链路检测feature

BGP配置BFD链路检测feature

作者: DennisYao | 来源:发表于2019-06-24 17:53 被阅读0次

    BGP路由技术和配置这边就不介绍了,本章主要介绍在BGP邻居建立成功的情况下启用BFD链路检测功能。

    BFD概述

    BFD(Bidirectional Forwarding Detection,双向转发检测)协议提供一种轻负载、快速检测两台邻接路由器之间转发路径连通状态的方法。协议邻居通过该方式可以快速检测到转发路径的连通故障,加快启用备份转发路径,提升现有网络性能。

    BFD报文格式

    BFD报文有两种类型分别是控制报文和回声报文。其中回声报文只有BFD会话本端系统关心远端不关心,因此协议没有规定其具体格式。协议只规定了控制报文的格式,目前控制报文格式有两个版本(版本0和版本1),BFD会话建立缺省采用版本1,但如果收到对端系统发送的是版本0的报文,将自动切换到版本0来建立会话,可以通过show bfd neighbors命令察看采用的版本。版本1的格式如图表1:


    图1.BFD控制报文格式

    Vers:BFD协议版本号,目前为1
     Diags:给出本地最后一次从UP状态转到其他状态的原因,包括:
    0—没有诊断信息
    1—控制超时检测
    2—回声功能失效
    3—邻居通告会话Down
    4—转发面复位
    5—通道失效
    6—连接通道失效
    7—管理Down
     Sta:BFD本地状态,取值为:0代表AdminDown,1代表Down,2代表Init,3代表Up;
     P:参数发生改变时,发送方在BFD报文中置该标志,接收方必须立即响应该报文
     F:响应P标志置位的回应报文中必须将F标志置位
     C:转发/控制分离标志,一旦置位,控制平面的变化不影响BFD检测,如:控制平面为OSPF,当OSPF重启/GR时,BFD可以继续检测链路状态
     A:认证标识,置位代表会话需要进行验证
     D:查询请求,置位代表发送方期望采用查询模式对链路进行检测
     M:用于将来应用点到多点时使用,目前必须设置0
     Detect Mult:检测超时倍数,用于检测方计算检测超时时间
     Length:报文长度
     My Discreaminator:BFD会话连接本端标识符
     Your Discreaminator:BFD会话连接远端标识符
     Desired Min Tx Interval:本地支持的最小BFD报文发送间隔
     Required Min RX Interval:本地支持的最小BFD报文接收间隔
     Required Min Echo RX Interval:本地支持的最小Echo报文接收间隔(如果本地不支持Echo功能,则设置0)
     Auth Type:认证类型(可选),目前协议提供有:
    Simple Password
    Keyed MD5
    Meticulous Keyed MD5
    Keyed SHA1
    Meticulous Keyed SHA1
     Auth Length:认证数据长度
     Authentication Data:认证数据区

    RGOS从10.3(4b3)版本开始,支持版本1和版本0的报文格式,缺省情况下会话发送报文采用版本1,如果收到对端发送的版本0的报文,将自动切换到版本0来建立会话
    

    BFD会话建立模式

    BFD会话建立包含如下几种模式
    主动模式
    在建立会话前不管是否收到对端发来的建立BFD会话的控制报文,都会主动发送建立BFD会话的控制报文。
    被动模式
    在建立对话前不会主动发送建立BFD会话的控制报文,直到收到对端发送来建立BFD会话的控制报文。

    RGOS10.4(1),10.3(4b3)版本不支持被动模式,且不可配置 
    

    BFD检测模式

    BFD可以包含如下几种检测模式:
    异步模式
    在异步模式下,系统之间相互周期性地发送BFD控制报文,如果某个系统在检测时间内没有收到对端发来的BFD控制报文,就宣布会话为Down
    查询模式
    在查询模式下,假定每个系统都有一个独立的方法用来确认它连接到其他系统。这样一旦一个BFD会话建立起来以后,系统停止发送BFD控制报文,除非某个系统需要显式地验证连接性,在需要显式验证连接性的情况下,系统发送一个短序列的BFD控制包,如果在检测时间内没有收到返回的报文就宣布会话为Down,如果收到对端的回应报文,表示转发路径正常。
    回声功能
    本地系统周期性的发送BFD 回声报文,远端系统通过它的转发通道将它们环回回来。如果本地在检测周期内连续几个回声报文都没有接收到,会话就被宣布为Down。回声功能可以和上述两种检测模式一起使用。采用回声报文的检测功能,不需要远端系统的控制面参与,报文通过远端系统的转发面转回,减少了延迟,相对于发送控制报文可以更快的检测到故障。如果在异步模式下启用回声功能,可以大大减少了控制报文的发送,因为检测工作由回声功能完成;如果在查询模式下启用回声功能,在会话建立后可以完全取消发送控制报文。BFD会话两点必须同时启用回声功能,否则回声功能将不生效。

    RGOS10.4(1)、RGOS10.3(4b3)版本不支持查询模式
    配置回声功能时,必须先通过no ip redirects命令关闭IP报文的重定向功能,以及通过no ip deny land命令关闭防止Land-based DDOS攻击功能
    BFD的回声功能只能在BFD会话工作在版本1时才能工作
    交换机产品S5760系列不支持配置回声功能.
    

    BFD会话参数

    在BFD会话建立以后,可以修订BFD会话参数(如Desired Min Tx Interval,Required Min RX Interval,Detect Mult等),修订后BFD会话将重新协商并采用最新参数进行会话检测,修订过程会话可以继续保持UP状态。

    BFD认证方式

    BFD协议允许采用如下方式进行认证:
    1. Simple Password
    2. Keyed MD5
    3. Meticulous Keyed MD5
    4. Keyed SHA1
    5. Meticulous Keyed SHA1

    RGOS10.4(1)、RGOS10.3(4b3)版本不支持BFD认证
    

    BFD支持与动态路由协议联动(BGP)

    BGPv4应用场景绝大部分是企业边界设备互联采用运营商固定互联网ip进行建立邻居关系,另一种就是企业各分部通过运营商专线进行互联,其实际就是一条就可以抵达。
    本章主要介绍后者,企业各分部通过运营商专线进行互联建立BGP邻居关系,优化主备线路切换原则。
    BGP是触发式更新,主线中断切换至备线,默认情况下需要180s来识别并切换。或者当你发现中断告警可以通过手工去clear ip bgp *硬清或clear ip bgp * soft软清邻居关系来收敛路由条目。

    简单的拓扑

    AB部门互联拓扑.jpg

    这种冗余架构应该都能看得懂吧,这边用GNS画了一张简单的拓扑图。
    要实现A部门PC1和B部门PC2之间能够正常访问,当AB部门主路由之间的链路断开后能无感知切换到备线进行通讯。
    首先A部门IBGP要通,B部门IBGP也要通。AB部门主备路由器EBGP邻居关系要建立。

    A部门主路由
    Neighbor        V           AS MsgRcvd MsgSent   TblVer  InQ OutQ Up/Down  State/PfxRcd
    202.101.1.2     4        64513      75      71    24544    0    0 00:49:32       26
    
    B部门主路由
    Neighbor        V           AS MsgRcvd MsgSent   TblVer  InQ OutQ Up/Down  State/PfxRcd
    202.101.1.1     4        64512      72      76    99480    0    0 00:50:33       66
    

    备路由器的邻居状态就不show出来了。

    A部门主路由器配置(Cisco3900)
    interface FastEthernet0/0/1
     ip address 202.101.1.1 255.255.255.252
     no ip redirects
     no ip unreachables
     no ip proxy-arp
     duplex full #双工
     speed 100 #百兆速率
     bfd interval 300 min_rx 300 multiplier 3
    
    router bgp 64512
     neighbor 202.101.1.2 remote-as 64513 #建立ebgp邻居
     neighbor 202.101.1.2 ebgp-multihop 2 #ebgp参数
     neighbor 202.101.1.2 fall-over bfd single-hop
    
    B部门备路由器配置(Cisco2900)
    interface FastEthernet0/0/0
     ip address 202.101.1.2 255.255.255.252
     no ip redirects
     no ip unreachables
     no ip proxy-arp
     duplex full
     speed 100
     bfd interval 300 min_rx 300 multiplier 3 #BFD具体参数,根据自己需求定义
    
    router bgp 64513
     neighbor 202.101.1.1 remote-as 64512
     neighbor 202.101.1.1 ebgp-multihop 2
     neighbor 202.101.1.1 fall-over bfd single-hop #单跳,当然也有多跳选项。如果用于互联固定ip用多跳即可
    

    show bfd neighbors details

    IPv4 Sessions
    NeighAddr                              LD/RD         RH/RS     State     Int
    202.101.1.2                              5/1          Up        Up        Fa0/0/1
    Session state is UP and using echo function with 300 ms interval.
    Session Host: Software
    OurAddr: 202.101.1.1     
    Handle: 3
    Local Diag: 0, Demand mode: 0, Poll bit: 0
    MinTxInt: 1000000, MinRxInt: 1000000, Multiplier: 3
    Received MinRxInt: 1000000, Received Multiplier: 3
    Holddown (hits): 0(0), Hello (hits): 1000(132363)
    Rx Count: 132462, Rx Interval (ms) min/max/avg: 4/1232/877 last: 736 ms ago
    Tx Count: 132364, Tx Interval (ms) min/max/avg: 756/1012/881 last: 448 ms ago
    Elapsed time watermarks: 0 0 (last: 0)
    Registered protocols: BGP CEF 
    Uptime: 1d08h
    Last packet: Version: 1                  - Diagnostic: 0
                 State bit: Up               - Demand bit: 0
                 Poll bit: 0                 - Final bit: 0
                 C bit: 0                                   
                 Multiplier: 3               - Length: 24
                 My Discr.: 1                - Your Discr.: 5
                 Min tx interval: 1000000    - Min rx interval: 1000000
                 Min Echo interval: 300000  
    

    配置时候遇到的坑

    我的实际环境是,各部门数据中心采用的是运营商主备线路冗余。逻辑上就是一跳。我们的边界设备都是cisco的,但是不是同一型号,有2900,2800,3900,4300系列的。所以在配置过程中出现了state bit状态是admin down。当时也是比较郁闷都是参照了配置手册进行的配置,为什么状态不是up而是admin down。
    配置过程中要注意的是端口的协商,比如全双工,速率要匹配。运营商专线以前配置双工会断,现在电信联通已经修补相关bug。
    这边还有就是cisco4300,接口下配置了neg auto,自动协商,no不掉的情况。需要在接口下配置media-type rj45,然后在no neg auto,在敲上duplex full,speed 100。
    这个时候基本大功告成,这个时候就要将设备进行重启。
    重启完后就可以看见bfd邻居建立。bfd具体参数根据自己企业的需求来定。我的配置参数基本可以达到无感知切换。

    相关文章

      网友评论

        本文标题:BGP配置BFD链路检测feature

        本文链接:https://www.haomeiwen.com/subject/yzyoqctx.html