文章目录
BGP 基础知识
- BGP 可以容纳上万条路由
- BGP 可以支持 MPLS VPN 传递客户数据
- 策略能力强,可以很好的实现路由决策和控制
- 刷新BGP命令 : refresh bgp all import / export
- BGP 的负载分担默认是 1 ,配置负载均衡的命令为 maximum local-balancing xx
BGP 邻居类型
IBGP 邻居:位于 AS 内部的邻居,位于相同的 AS
EBGP 邻居:位于 AS 外部的邻居,位于不同的 AS
BGP 邻居的概述
-
BGP Speakers :运行 BGP 的路由器
-
BGP peer :BGP 对等体(邻居)
-
一个 BGP 路由器只能在一个 AS 区域
-
BGP 邻居可以跨越设备提供建立
-
BGP 邻居关系是建立在 TCP 连接的基础上 因此邻居不一定需要直连,可以通过 IGP 来提供 TCP 的连接的可达性
使用 loopback 接口来建立邻居必须保证 TCP 可达
BGP 报文形式
- Open:类似于 Hello 用于建立邻居的连接
- Keep live:类似于 Hello 维护邻居关系,60s发送一次 180s 老化
- Update:路由更新,包含属性
- Notification:当检测到错误,发送后关闭 BGP 连接
- Route-refresh:当路由策略发生变化时,触发请求邻居重新通告路由
BGP 状态
- Idle----初始 路由器查找路由表,是否有到达邻居的路由
- connect----发送 TCP 连接,等待 TCP 连接成功
- Active----TCP 连接失败,继续尝试 TCP 连接
- Open sent ----TCP 连接成功 发送 Open 包
- Open Confirm----已经收到对端发送的 Open 包,如果没有收到 则会进入 Active 状态
- Established----邻居建立完成,开始传递最优路由
BGP 路由宣告原则
- 缺省情况下 BGP 不会发布任何路由
- 只有明确宣告的网络才会发给邻居
- 宣告的网络必须能精确的在路由表中找到
- 多条路径时,只会选择最优的路由给自己用
- 只把自己最优的路由给邻居
- 从 EBGP 学习到的路由会宣告给所有邻居
- 从 IGBP 学习到的路由不会宣告给 IBGP 邻居(为了解决此问题一般在 IBGP 使用全互联)
- 从 IBGP 学习到的路由会宣告给 EBGP 邻居
成为 BGP 路由的方法
本地宣告
-
network----该方法生成的路由属性为 " i "
宣告路由,精确匹配并存在于路由表
-
peer----生成的方式也是 " i "
引入宣告
-
import----该方法生成的路由属性为 " ? "
通常会搭配着路由策略进行运用
BGP 中的缺省路由
BGP里面引入缺省路由
-
ip route-static 0.0.0.0 0.0.0.0 NULL0 // 创建缺省路由
BGP 下 输入 default-route imported // 引入缺省路由 默认不允许
直接向邻居下放缺省路由
- peer x.x.x.x default-route-advertise // 直接向邻居下发缺省路由
BGP 的下一跳问题
BGP 在给邻居传递路由时的下一跳 = 更新源
在 EBGP 间传递时会修改下一跳为自己的更新源
在 IBGP 间传递时不会修改下一跳为自己的更新源
peer x.x.x.x next-hop-local // 对邻居说下一跳走我
BGP 的防环机制
IBGP----水平分割
IBGP 因为从 IBGP 学习到的路由不会传递给其他的 IBGP 邻居(IBGP 更新只传一跳)
为了解决IBGP传递问题推出了几种方案:
- IBGP 全互联--------配置 维护开销大
- 路由反射器RR--------不能解决路由黑洞的问题,可以解决全互联的问题
- 联盟(也可以成为联邦)
EBGP----AS_path
BGP 更新内的重要属性,代表该路由经过的 AS 号,如果接受到的路由器发现 AS 号和本地一致,则丢弃----100 200?// 从左到右是新旧
作者:DC
未经允许不得转载