OSPF 邻居状态机

1. Down

没有收到对端的hello报文

2. Attempt(MA网络)

老化时间内未收到邻居hello报文

3. Init

收到了邻居的hello报文,但报文中没有本地 RID

4. 2Way

收到的邻居hello报文,且其中包含了本地 RID

---> 邻居关系建立完成,MA网络此时会进行DR/BDR选举,以减少网络中建立邻接关系的数量。选举完毕后DR other于DR/BDR进行下一阶段开始建立邻接关系.

5. ExStart - 选主从

通过空的DD报文选举主从(RID大的设备为主),保证在后续的DD报文交换中能够有序的发送。

DD报文中不包含LSA摘要, 只有三个标志位I,M,MS

 initial - 第一个DD报文

 more - 后面还有DD报文; 0 表示没有DD报文了。

 master/slave - 表示该报文为主,0表示为从

此时报文的MTU值会影响状态机的建立,主大从小,两边都卡在exstart状态;主小从大,主看从卡在exstart,丛看主卡在exchange。

* "从"路由器,回复一个MS 位设置为0的DD描述数据包------这个数据库描述数据包的序列号设置为"主"路由器的序列号。同时,这个数据库描述数据包也将是第一个携带LSA 摘要信息的数据包。

6. Exchange - 交互DD

本端设备将本地的LSDB用DD报文来描述,并发给邻居设备。

  1. 主路由器控制LSDB列表的同步过程, 并确保每次只有一个DD是未处理的。主路由器定义一个序列号Seq,每发送一个新的DD报文将Seq加1..

  2. 从路由器每次发送DD报文时使用接收到的DD报文中的 Seq 响应主路由器。

  3. 主从路由器都发送M标志位为0的DD(路由器已经完全描述了它自己的LSDB),表示LSDB列表同步完成。

7. Loading - 同步LSDB (交互LSR,LSU,LSAck)
  1. 本地路由器将本地没有的/比本地更新的LSA放入LSR列表, 以请求完整的LSA。

  2. 对端用 LSU报文来回应LSR

  3. 本地路由器收到LSU后,从LSR列表中删除相应LSA条目并发送LSAck报文确认。

* LSU中的LSA必须单独确认,因此路由器会将这些传送的LSA放到每个邻居的链路状态重传列表中,每隔RxmtInterval 的时间重传一次. 直到该LSA得到确认,或邻接关系中断, 路由器就会将其从重传列表删除。

*事实上,当邻居状态还依旧是Exchange 状态时路由器就可以发送链路状态请求数据包了。

8. Full - LSDB同步完全

LSR列表为空,路由器将会把邻居的状态转换到Full状态

相关推荐
我命由我123457 小时前
Java NIO 编程 - NIO Echo Server、NIO Client(NIO 异步客户端、NIO Selector 异步客户端)
java·开发语言·网络·java-ee·intellij-idea·intellij idea·nio
kk哥88999 小时前
iOS开发:关于日志框架
网络·ios·cocoa
m***D28613 小时前
云原生网络
网络·云原生
u***276113 小时前
C#数据库操作系列---SqlSugar完结篇
网络·数据库·c#
阿珊和她的猫15 小时前
HTTP 状态码 304:未修改(Not Modified)的深度解析
网络协议·http·状态模式
jinxinyuuuus17 小时前
局域网文件传输:P2P架构中NAT穿透、打洞与数据安全协议
网络协议·架构·p2p
q***160818 小时前
IP地址、子网掩码(NETMASK)和网关(Gateway)
tcp/ip·gateway·智能路由器
chuxinweihui18 小时前
应用层协议 HTTP
linux·服务器·网络·网络协议·http
chuxinweihui18 小时前
HTTP cookie 与 session
网络·网络协议·http
RocketJ18 小时前
TCP、Telepathy 和 HTTP 三者关系
网络协议·tcp/ip·http