1 OSPF协议概述
1.1 动态路由协议背景
静态路由是由工程师手动配置和维护的路由条目,命令行简单明确,适用于小型或稳定的网络。静态路由有以下问题:
无法适应规模较大的网络:随着设备数量增加,配置量急剧增加。
无法动态响应网络变化:网络发生变化,无法自动收敛网络,需要工程师手动修改。

1.2 动态路由协议分类
按工作区域分类:
IGP (Interior Gateway Protocols, 内部网关协议)、EGP (Exterior Gateway Protocols, 外部网关协议)
按工作机制及算法分类:
(Distance Vector Routing Protocols,距离矢量路由协议)、(Link-State Routing Protocols, 链路状态路由协议)

1.3 距离矢量路由协议
运行距离矢量路由协议的路由器周期性的泛洪自己的路由表。通过路由的交互,每台路由器都从相邻的路由器学习到路由,并且加载进自己的路由表中。
对于网络中的所有路由器而言,路由器并不清楚网络的拓扑,只是简单的知道要去往某个目的方向在哪里,距离有多远。这即是距离矢量算法的本质。

1.4 链路状态路由协议
1.LSA泛洪
与距离矢量路由协议不同,链路状态路由协议通告的的是链路状态而不是路由表。
运行链路状态路由协议的路由器之间首先会建立一个协议的邻居关系,然后彼此之间开始交互LsA(Link State Advertisement,链路状态通告)。

2.LSDB组建
每台路由器都会产生LSAs,路由器将接收到的LSAs放入自己的LSDB(Link State DataBase,链路状态数据库)。路由器通过LSDB,掌握了全网的拓扑。

3.SPF计算
每台路由器基于LSDB,使用SPF(Shortest Path First,最短路径优先)算法进行计算。
每台路由器都计算出一棵以自己为根的、无环的、拥有最短路径的”树”。有了这棵”树”,路由器就已经知道了到达网络各个角落的优选路径。

4.路由表生成
路由器将计算出来的优选路径,加载进自己的路由表(Routing Table)。

5.链路状态路由协议总结

1.5 OSPF简介
OSPF是典型的链路状态路由协议,是目前业内使用非常广泛的IGP协议之一。
目前针对IPv4协议使用的是OSPF Version 2(RFC2328);针对IPv6协议使用OSPF Version 3(RFC2740)。
运行OSPF路由器之间交互的是LS(Link State,链路状态)信息,而不是直接交互路由。LS信息是OSPF能够正常进行拓扑及路由计算的关键信息。
OSPF路由器将网络中的LS信息收集起来,存储在LSDB中。路由器都清楚区域内的网络拓扑结构,这有助于路由器计算无环路径。
每台OSPF路由器都采用SPF算法计算达到目的地的最短路径。路由器依据这些路径形成路由加载到路由表中。
OSPF支持VLSM(Variable Length Subnet Mask,可变长子网掩码),支持手工路由汇总。
多区域的设计使得OSPF能够支持更大规模的网络。
OSPF在园区网络的应用:

1.6 OSPF基础术语
1.6.1 区域
OSPF Area用于标识一个OSPF的区域。
区域是从逻辑上将设备划分为不同的组,每个组用区域号(Area ID)来标识。

1.6.2 Route-ID
Router-ID(Router Identifier,路由器标识符),用于在一个OSPF域中唯一地标识一台路由器。
Router-ID的设定可以通过手工配置的方式,或使用系统自动配置的方式。

1.6.3 度量值
OSPF使用Cost(开销)作为路由的度量值。每一个激活了OSPF的接口都会维护一个接口Cost值,缺省时接口Cost值=(100Mbit/s)/接口带宽。其中100 Mbit/s为OSPF指定的缺省参考值,该值可配置。
一条OSPF路由的Cost值可以理解为是从目的网段到本路由器沿途所有入接口的Cost值累加。

1.6.4 OSPF协议报文类型
OSPF有五种类型的协议报文,这些报文在OSPF路由器之间交互中起不同的作用。
| 报文名称 | 报文功能 |
|---|---|
| Hello | 周期性发送,用来发现和维护OSPF邻居关系。 |
| Database Description | 描述本地LSDB的摘要信息,用于两台设备进行数据库同步。 |
| Link State Request | 用于向对方请求所需要的LSA。 设备只在0SPF邻居双方成功交换DD报文后才向对方发出LSR报文。 |
| Link State Update | 用于向对方发送其所需要的LSA。 |
| Link State ACK | 用来对收到的LSA进行确认。 |
1.7 OSPF三大表项
OSPF有三张重要的表项,OSPF邻居表、LSDB表和OSPF路由表。
1.7.1 OSPF邻居表
OSPF在传递链路状态信息之前,需先建立OSPF邻居关系。
OSPF的邻居关系通过交互Hello报文建立。
OSPF邻居表显示了OSPF路由器之间的邻居状态,使用display ospf peer查看。

1.7.2 LSDB表
LSDB会保存自己产生的及从邻居收到的LSA信息,本例中R1的LSDB包含了三条LSA。
Type标识LSA的类型,AdvRouter标识发送LSA的路由器。
使用命令行display ospf Isdb查看LSDB表。

1.7.3 OSPF路由表
OSPF路由表和路由器路由表是两张不同的表项。本例中OSPF路由表有三条路由。
OSPF路由表包含Destination、Cost和NextHop等指导转发的信息。
使用命令display ospf routing查看OSPF路由表。

2 OSPF协议工作原理
2.1 OSPF路由器之间的关系
关于OSPF路由器之间的关系有两个重要的概念,邻居关系和邻接关系。
考虑一种简单的拓扑,两台路由器直连。在双方互联接口上激活OSPF,路由器开始发送及侦听Hello报文。在通过Hello报文发现彼此后,这两台路由器便形成了邻居关系。
邻居关系的建立只是一个开始,后续会进行一系列的报文交互,例如前文提到的DD、LSR、LSU和LS ACK等。当两台路由器LSDB同步完成,并开始独立计算路由时,这两台路由器形成了邻接关系。
2.2 OSPF邻接关系建立
OSPF完成邻接关系的建立有四个步骤:建立邻居关系、协商主/从、交互LSDB信息、同步LSDB。

1.OSPF邻接关系建立流程1

2.OSPF邻接关系建立流程2&3

3.OSPF邻接关系建立流程4

2.3 OSPF邻居表回顾

2.4 OSPF网络类型
OSPF网络类型是一个非常重要的接口变量,这个变量将影响0SPF在接口上的操作,例如采用什么方式发送OSPF协议报文,以及是否需要选举DR、BDR等。
接口默认的OSPF网络类型取决于接口所使用的数据链路层封装。
如下图所示,0SPF的有四种网络类型,Broadcast、NBMA、P2MP和P2P。

1.OSPF网络类型1
一般情况下,链路两端的0SPF接口网络类型必须一致,否则双方无法建立邻居关系。
OSPF网络类型可以在接口下通过命令手动修改以适应不同网络场景,例如可以将BMA网络类型修改为P2P。
P2P:
P2P指的是在一段链路上只能连接两台网络设备的环境。
典型的例子是PPP链路。当接口采用PPP封装时,OSPF在该接口上采用的缺省网络类型为P2P。
BMA:
BMA也被称为Broadcast,指的是一个允许多台设备接入的、支持广播的环境。
典型的例子是Ethernet(以太网)。当接口采用Ethernet封装时,0SPF在该接口上采用的缺省网络类型为BMA。

2.OSPF网络类型2
NBMA指的是一个允许多台网络设备接入且不支持广播的环境,典型的例子是帧中继(Frame-Relay)网络。
P2MP相当于将多条P2P链路的一端进行捆绑得到的网络。
没有一种链路层协议会被缺省的认为是P2MP网络类型。该类型必须由其他网络类型手动更改。常用做法是将非全连通的NBMA改为点到多点的网络。

2.5 DR与BDR
2.5.1 DR与BDR背景
MA(Multi-Access)多路访问网络有两种类型:广播型多路访问网络(BMA)及非广播型多路访问网络(NBMA)。以太网(Ethernet)是一种典型的广播型多路访问网络。
在MA网络中,如果每台OSPF路由器都与其他所有路由器建立OSPF邻接关系,便会导致网络中存在过多的OSPF邻接关系,增加设备负担,也增加了网络中泛洪的OSPF报文数量。
当拓扑出现变更,网络中的LSA泛洪可能会造成带宽的浪费和设备资源的损耗。

2.5.2 DR与BDR概念
为优化MA网络中OSPF邻接关系,OSPF指定了三种OSPF路由器身份,DR(Designated Router,指定路由器)、BDR(Backup Designated Router,备用指定路由器)和DRother路由器。
只允许DR、BDR与其他OSPF路由器建立邻接关系。DRother之间不会建立全毗邻的OSPF邻接关系,双方停滞在2-way状态。
BDR会监控DR的状态,并在当前DR发生故障时接替其角色。

2.6 OSPF域与单区域

OSPF域(Domain):一系列使用相同策略的连续OSPF网络设备所构成的网络。
OSPF路由器在同一个区域(Area)内网络中泛洪LSA。为了确保每台路由器都拥有对网络拓扑的一致认知,LSDB需要在区域内进行同步。
如果OSPF域仅有一个区域,随着网络规模越来越大,OSPF路由器的数量越来越多,这将导致诸多问题:
LSDB越来越庞大,同时导致OSPF路由表规模增加。路由器资源消耗多,设备性能下降,影响数据转发。
基于庞大的LSDB进行路由计算变得困难。
当网络拓扑变更时,LSA全域泛洪和全网SPF重计算带来巨大负担。
2.7 OSPF多区域

OSPF引入区域(Area)的概念,将一个OSPF域划分成多个区域,可以使OSPF支撑更大规模组网。
OSPF多区域的设计减小了LSA泛洪的范围,有效的把拓扑变化的影响控制在区域内,达到网络优化的目的。
在区域边界可以做路由汇总,减小了路由表规模。
多区域提高了网络扩展性,有利于组建大规模的网络。
2.8 OSPF路由器类型
OSPF路由器根据位置或功能不同,有几种类型:
区域内路由器(Internal Router)
区域边界路由器ABR(Area Border Router)
骨干路由器(Backbone Router)
自治系统边界路由器ASBR(AS Boundary Router)

2.9 OSPF单区域&多区域组网

3 OSPF协议配置
1.(系统视图)创建并运行OSPF进程
[Huawei] ospf [ process-id | router-id router-id ]
# porcess-id用于标识OSPF进程,默认进程号为1。
# OSPF支持多进程,在同一台设备上可以运行多个不同的OSPF进程,它们之间互不影响,彼此独立。
# router-id用于手工指定设备的ID号。如果没有通过命令指定ID号,系统会从当前接口的IP地址中自动选取一个作为设备的ID号。
2.(OSPF视图)创建并进入OSPF区域
[Huawei-ospf-1] area area-id
# area命令用来创建OSPF区域,并进入OSPF区域视图。
# area-id可以是十进制整数或点分十进制格式。采取整数形式时,取值范围是0~4294967295。
3.(OSPF区域视图)指定运行OSPF的接口
[Huawei-ospf-1-area-0.0.0.0] network network-address wildcard-mask
# network命令用来指定运行OSPF协议的接口和接口所属的区域。
# network-address为接口所在的网段地址。
# wildcard-mask为IP地址的反码,相当于将IP地址的掩码反转(0变1,1变0),例如0.0.0.255表示掩码长度24 bit。
4.(接口视图)配置OSPF接口开销
[Huawei-GigabitEthernet0/0/0] ospf cost cost
# ospf cost命令用来配置接口上运行OSPF协议所需的开销。
# 缺省情况下,OSPF会根据该接口的带宽自动计算其开销值。
# cost取值范围是1~65535。
5.(OSPF视图)设置OSPF带宽参考值
[Huawei-ospf-1] bandwidth-reference value
# bandwidth-reference命令用来设置通过公式计算接口开销所依据的带宽参考值。
# value取值范围是1~2147483648,单位是Mbit/s,缺省值是100Mbit/s。
6.(接口视图)设置接口在选举DR时的优先级
[Huawei-GigabitEthernet0/0/0] ospf dr-priority priority
# ospf dr-priority命令用来设置接口在选举DR时的优先级。
# priority值越大,优先级越高,取值范围是0~255。