边界网关协议(英語:Border Gateway Protocol,缩写:BGP)是互联网上一个核心的去中心化自治路由协议。 它经过维护IP路由表或'前缀'表来实现自治系统(AS)之间的可达性,属于矢量路由协议。 |
1、了解BGP协议html
BGP 是一种路径矢量路由协议,用于传输自治系统间的路由信息,BGP 在启动的时候传播整张路由表,之后只传播网络变化的部分触发更新它采用 TCP 链接传送信息,端口号为 179 在 Internet 上,BGP 须要通告的路由数目极大,因为 TCP 提供了可靠的传送机制,同时 TCP 使用滑动窗口机制,使得 BGP 能够不断地发送分组,而无需像 OSPF 或 EIGRP 那样中止发送并等待确认。linux
1. 使用 BGP 通常有以下状况:网络
一个 AS 容许包穿越它,到达其余的 AS
一个 AS 链接多个 AS
必须对数据流进入和离开 AS 进行控制oop
2. 不使用 BGP 通常有以下状况:性能
AS 只有一个出口
AS 的全部出口均为 1 个 ASP
路由性能不高,内存较小,CPU 较慢,带宽不大orm
3. 认识BGP AS-Pathrouter
BGP 是路径矢量协议,它使用一个 AS 号列表,数据包必须经过这些 AS 才能到达目的,同时对产生的 AS-path 作必定的策略。AS-Path 对于路由环路很是容易检测到,若是路由器接受到一条含有本地 AS 号的 AS-path,说明出现环路。BGP 没有给出每一个 AS 域内的拓扑结构,所以 BGP 只能看到 AS 树,而 IGP 只能看到 AS 域内拓扑结构.
当某个特殊目的网络有并列的,等开销的路径时,Cisco 缺省执行 EBGP 只选择一条路径,但能够使用 maximum-paths改变并行路径缺省的最大数目,但仅对 EBGP 有效htm
2、BGP消息类型blog
1. Open接口
TCP 对话创建之后,两个邻居都要发送一个 Open 消息,每一个邻居都用该消息来标示本身,并规定本身的 BGP 运行参数。
BGP version:它明确了发起者正在运行的 BGP 版本号(2,3,4),能够经过 neighbor version 修改,缺省版本号为 4。若是版本号不相同,路由器将自动下降版本号重发 Open 消息,直到版本一致
AS number:发起会话路由器的 AS 号,用于确认 EBGP 或者 IBGP 会话
Hold time:路由器必须收到一个 keepalive 或者更新消息以前容许通过的最大秒数。Holdtime 必须是 0(在这种状况下,必须是没有发送 Keepalive)或者至少 3s Cisco 默认的 holdtime 为 180s,若是两个邻居间 holdtime 不一致,选较短的那个作为二者可接受的时间
BGP router-ID:选取方式和 OSPF 相同,使用数值最大的 loopback 口地址,没有 loopback 则使用物理接口上数值最大的地址
Optional parameters:用于一些可选功能的支持.例如鉴别,多协议支持及路由刷新等
2. Keepalive
若是路由器接受了他在邻居的 Open 消息中的参数,它就会发送一个应答的 Keepalive 消息。
默认状况 Keepalive 间隔 60s,或者是达成一致的保持时间的 1/3
3. Update
Update message 用来公布可用的路由,撤销的路由或者二者兼顾Network Layer Reachability Information (NLRI)用来公布 IP 地址前缀和前缀长度的字节组,例如<19,198.24.160.0>Path Attributes该属性为 BGP 提供了选择最短路径,检查到路由环路以及决定路由策略的信息Withdrawn Routes用来描述已经变成不可达并正从业务中撤销的目的地址字节组(长度和前缀)虽然 NLRI 字段能够包含多个前缀,但每个更新消息只描述一条 BGP 路由(由于路径属性只描述一条路径,但该路径可能会到达多个目的地)
4. Notification
当检测到差错的时候就会发送 Notification 消息,一般会致使 BGP 链接终止。