BGP数据包+工作过程

BGP数据包

基于 TCP的179端口工作;故BGP协议中所有的数据包均需要在tcp 会话建立后;

基于TCP的会话来进行传输及可靠性的保障;

首先通过TCP的三次握手来寻找到邻居;

Open 仅负责邻居关系的建立,正常进收发一次即可;携带route-id;

Keeplive 保活 周期 1min 查询邻居关系是否存在;实际保活TCP会话; hoid time 默认 3min

Update 携带路由条目 目标网络号+各种属性

Notification 出现错误数据时收发

BGP 的工作过程

1.配置完成后,邻居间单播 TCP 三次握手,目标端口179,建立TCP 的会话;之后所有的BGP 协议数据包基于该会话进行传输;会话建立后,邻居间正常收发一次 open 报文建立 BGP 的邻居关系,生成邻居表BGP 协议的 open 报文中将携带本地的 RID-生成方式和 OSPF 一致;仅需要本地及本地所有邻居唯一即可;邻居关系建立后,默认每1min,使用keeplive 周期保活邻居关系(周期保活 TCP 会话)


IP可达之后,管理员手工告知邻居的ip地址;自动通过三次握手建立TCP的会话;会话建立后,BGP协议收发一次open报文,双方获取对端RID,建立邻居关系,生成邻居表;

邻居关系建立后,可用update共享路由条目;keeplive默认每1分周期保活一次tcp会话;

获取路由后,生成BGP表;------装载所有本地发出以及接收到BGP路由;

基于BGP的默认属性和选路规则,将BGP表中最优加载到本地路由表中;

2、邻居关系建立后,管理员选择性将本地路由表中通过任意来源获取的路由条目,向BGP协议中进行宣告;使用 updata数据包进行邻居间路由共享;之后生成 BGP 表------装载本地发出及接收到的所有路由条目;

默认将最优路径加载于路由表中(最优-仅仅基于BGP的选路规则,不一定为最佳路径;BGP默认不支持负载均衡)

3、收敛完成,仅 keeplive 周期保活即可

4、若出现错误信息,邻居间将使用 Notification 报文进行报错操作

5、结构突变

1)新增------本地使用 updata 向本地所有邻居告知,前提该路由不被已经发出的聚合路由包含.

2)断开------本地使用 updata 向本地所有邻居告知,前提该路由不被已经发出的聚合路由包含只有 到聚合条目中包含的所有明细路由均在本地失效,才告知邻居删除聚合条目

3)无法沟通 ------ hold time为 3min,连续3次未收到邻居的keeplive;断开邻居关系、TCP 会话,删除从该邻居处学习到的所有路由;

相关推荐
江团1io02 小时前
深入解析TCP核心机制:连接管理、流量与拥塞控制
服务器·网络·tcp/ip
磊灬泽2 小时前
【日常错误】鼠标无反应
linux·windows
知白守黑2672 小时前
Ansible角色
运维·服务器·ansible
海拥✘6 小时前
深入理解 IP 地址:概念、分类与日常应用
网络·网络协议·tcp/ip
Miracle&6 小时前
2.TCP深度解析:握手、挥手、状态机、流量与拥塞控制
linux·网络·tcp/ip
专注API从业者7 小时前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python
liulilittle7 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
Ribou7 小时前
Ubuntu 24.04.2安装k8s 1.33.4 配置cilium
linux·ubuntu·kubernetes
c&0xff007 小时前
Flink反压问题
网络·flink
深圳多奥智能一卡(码、脸)通系统8 小时前
基于多奥(DAIC)品牌的IC卡电梯门禁系统(梯控)基础配置清单,整合核心硬件、软件及安全组件,确保系统可独立运行并支持未来扩展
网络