OSPF报文头部
- Version:OSPF协议号,应当被设置成2。
- Type:OSPF报文类型,OSPF共有五种报文。
- Packet length:OSPF报文总长度,包括报文头部。单位是字节。
- Router ID:生成此报文的路由器的Router ID。
- Area ID:此报文需要被通告到的区域。
- Checksum:是指一个对整个数据包(包括包头)的标准IP校验和。
- AuType:验证此报文所应当使用的验证方法。
- Authentication:验证此报文时所需要的密码等信息。
验证合法OSPF报文头部:
验证一个OSPF报文头部是否合法包括:
- 1.Version必须为2;
- 2.Area ID应当满足以下两种情况之一:
- 和接收端口所属区域的Area ID一致;
- 和接收端口所属区域的Area ID不一致,但是值为0,表示该报文属于骨干区域,而且是在一个虚连接上发送的;
- 3.AuType字段必须与该区域配置的Autype一致;
- 4.Authentication为验证信息,内容与AuType字段相关。
- 只有通过验证的OSPF报文才能被接受,否则将不能正常建立邻居关系。
- VRP支持两种验证方式:区域验证方式和接口验证方式。当两种验证方式都存在时,优先使用接口验证方式。
OSPF协议头部报文示例:
Hello报文
- Network Mask:发送Hello报文的接口的网络掩码。
- HelloInterval:发送Hello报文的时间间隔。单位为秒。
- Options:标识发送此报文的OSPF路由器所支持的可选功能。
- E:允许Flood AS-External-LSAs;
- MC:转发IP组播报文;
- N/P:处理Type-7 LSAs;
- DC:处理按需链路。
- Rtr Pri:发送Hello报文的接口的Router Priority,用于选举DR和BDR。
- RouterDeadInterval:宣告邻居路由器不继续在该网段上运行OSPF的时间间隔,单位为秒,通常为四倍HelloInterval。
- Designated Router:发送Hello报文的路由器所选举出的DR的IP地址。如果设置为0.0.0.0,表示未选举DR路由器。
- Backup Designated Router:发送Hello报文的路由器所选举出的BDR的IP地址。如果设置为0.0.0.0,表示未选举BDR路由器。
- Neighbor:邻居路由器的Router ID列表。表示本路由器已经从该邻居收到合法的Hello报文。
报文示例:
验证合法Hello报文:
- 验证一个Hello报文是否合法之前首先需要验证一个OSPF报文是否合法。
验证一个接收到的Hello报文是否合法包括:
- 1. 如果接收端口的网络类型是广播型,点到多点或者NBMA,所接收的Hello报文中Network Mask字段必须和接收端口的网络掩码一致,如果接收端口的网络类型为点到点类型或者是虚连接,则不检查Network Mask字段;
- 2. 所接收的Hello报文中的HelloInterval字段必须和接收端口的配置保持一致;
- 3. 所接收的Hello报文中的RouterDeadInterval字段必须和接收端口的配置保持一致;
- 4. 所接收的Hello报文中的Options字段中的E-bit(表示是否接收外部路由信息)必须和相关区域的配置保持一致。关于此比特的具体意义将在《OSPF特殊区域》中详细解释。
- 如果路由器发现所接收的合法Hello报文的邻居列表中有自己的Router ID,则认为已经和邻居建立了双向连接,表示邻居关系已经建立。
DD报文
- 接口MTU:是指在数据包不分段的情况下,始发路由器接口可以发送的最大IP数据包大小。当在虚连接时,该字段为0x0000。
- Option:标识发送此报文的OSPF路由器所支持的可选功能。
- E:允许Flood AS-External-LSAs;
- MC:转发IP组播报文;
- N/P:处理Type-7 LSAs;
- DC:处理按需链路。
- I位:Init bit,当发送的是一系列DD报文中的第一个数据包时,该位置为1。后续的DD报文将该位置为0。
- M位:More bit,当发送的数据包还不是一个系列DD报文中的最后一个数据包时,该位置为1。如果是最后一个DD报文,则将该位置为0。
- M/S位:Master/Slave bit,在数据库同步中,主要用来确认协商过程中的序列号。
- DD Sequence Number: 4bytes,DD的报文序列号。
- LSA Headers:可变长度,该DD报文中所包含的LSA的头部信息。
报文示例:
LSR报文
- Link State Advertisement Type:用来指明LSA标识是一个路由器LSA、一个网络LSA还是其他类型的LSA。
- Link State ID:不同类型LSA该字段意义不同。
- Advertising Router:始发LSA通告的路由器的路由器ID。
报文示例:
LSU报文
- Number of LSA:指出这个数据包中包含的LSA的数量。
- LSA:明细LSA信息,在LSA类型中有详细介绍
报文示例:LSA详细信息
LSAck报文:
- Header of LSA:LSA头部信息,通过LSA的头部信息确认收到该LSA
报文示例: