如何解决bgp路由在igp路由表中抖动
日期:2007-09-23 荐:
·路由协议-BGP路由协议典型配置·IP骨干网BGP路由协议扩展性详细介绍·BGP路由反射-network实验笔记 as9806 as4808 R1------------------------------------------R2 1.1.1.1/24 1.1.1.2/24 lo0:10.10.10.10/32 lo0:20.20.20.20/32 lo1:20.20.20.21/32 基本配置: r1: router bgp 9806 nei 20.20.20.20 remote-as 4808 bgp router-id 1.1.1.1 r2: router bgp 4808 nei 1.1.1.1 remote-as 9806 nei 1.1.1.1 update-source lo0 bgp router-id 20.20.20.20 network 20.20.20.21 mask 255.255.255.255 只有以上配置r1和r2的bgp邻居关系是建立不起来的,一定要记住还需在r1上配置 nei 20.20.20.20 ebgp-multihop 此时r1还需可达20.20.20.20,因此在r1配置 ip route 0.0.0.0 0.0.0.0 1.1.1.2 //因为as9806是个末节点,所以只配置了默认路由,这也是导致下面问题出现的原因 配置以上命令后bgp邻居关系成功建立,r2把20.20.20.21/32(next-hop:20.20.20.20) 的update发送给r1,r1收到更新把20.20.20.21/32后放入bgp和igp路由表,此后r1会在查询igp路由表20.20.20.21的下一跳20.20.20.20是否可达,发现20.20.20.20可通过默认路由到达,最终20.20.20.21/32(next-hop:20.20.20.20)会保留在igp路由表中。 问题出现!!! 这时,管理员为了让r2为了便于管理,就把r2的loopback0通过bgp发布出去 network 20.20.20.20 mask 255.255.255.255 r2向r1发布新的update,20.20.20.20/32(next-hop:20.20.20.20),r1收到update后把路由装入bgp和igp路由表。此时r1在igp路由表中查询20.20.20.20/32的下一跳仍为20.20.20.20(最长匹配,因此也就不会再继续查询默认路由了),这明显不合乎逻辑(自己不能信任自己),因此将所有下一跳为20.20.20.20的路由从igp路由表中删除,也就是20.20.20.20/32和20.20.20.21/32。过一会r2仍会发送新的update,r1又会重复刚才的动作,最终导致了通过bgp学到路由在igp路由表中一直振荡。 解决办法: 在r1上配置 ip route 20.20.20.20 255.255.255.255 1.1.1.2 当r1在收到20.20.20.20/32的update后,装入bgp和igp路由表,查询20.20.20.20的下一跳通过上面配置的静态路由可达,r1保持此路由在igp路由表中,因此就不会出现上面bgp路由在igp路由表中振荡的结果了。 最后注意: 1.当对方用来和自己建立bgp邻居关系用的接口和自己不是直连时,一定要配置一条静态路由指向对方的bgp neighbor地址 2.对方使用loopback建立bgp邻居关系时,自己一定要配置一条ebgp-multihop
标签: