千家信息网

链路状态路由协议——OSPF路由协议(理论篇)

发表于:2024-10-24 作者:千家信息网编辑
千家信息网最后更新 2024年10月24日,OSPF路由协议概述:OSPF--开放式最短路径优先选择协议 OSPF是一个内部网关协议(Interior Gateway Protocol,简称IGP),用于在单一自治系统(autonomous s
千家信息网最后更新 2024年10月24日链路状态路由协议——OSPF路由协议(理论篇)

OSPF路由协议概述:

OSPF--开放式最短路径优先选择协议 OSPF是一个内部网关协议(Interior Gateway Protocol,简称IGP),用于在单一自治系统(autonomous system,AS)内决策路由。它是对链路状态路由协议的一种实现,隶属内部网关协议(IGP),故运作于自治系统内部。自治系统(AS)AS指的是处于一个管理机构控制之下的路由器和网络群组。它可以是一个路由器直接连接到一个LAN上,同时也连到Internet上;它可以是一个由企业骨干网互连的多个局域网。在一个自治系统中的所有路由器必须相互连接,运行相同的路由协议,同时分配同一个自治系统编号。一个AS只能运行一种路由协议。内部网关协议(IGP)IGP是在一个自治网络内网关(主机和路由器)间交换路由信息的协议。路由信息能用于网间协议(IP)或者其它网络协议来说明路由传送是如何进行的。Internet网被分成多个域或多个自治系统。一个域是一组主机和使用相同路由选择协议的路由器集合,并由单一机构管理。IGP协议例如:RIP、OSPF、IS-IS等。外部网关协议(EGP)EGP是一个在自治系统网络中两个邻近的网关主机(每个都有它们自己的路由)间交换路由信息的协议。EGP常常被用来在英特网的两个主机间交换路由表信息。路由表包括已知的路由器清单、它们能到达的地址以及与每个路由的路径相关的成本度量,以便选出最好的可用路径。每个路由器按照一定的时间间隔,通常在120秒到480秒之间,就给它的邻近路由发送信息,然后邻近路由就会将自己的完整路由表发回给它。EGP协议例如:BGP等。

OSPF的工作过程

              建立邻接关系→→ 链路状态数据库→→最短路径数→→路由表                   学习链路状态信息    Dijkstra算法

OSPF的特点

可适应大规模网络路由变化收敛速度快无路由环支持变长子网掩码VLSM支持区域划分支持以组播地址发送协议报

OSPF区域

OSPF在AS内划分多个区域。每个OSPF路由器只维护所在区域的完整链路状态信息。Area0--骨干区域(核心)(默认唯一)所有其他的Area仅连接Area0

区域ID

区域ID可以表示成一个十进制的数字也可以表示成一份IP

Router ID

OSPF区域内唯一标识路由器的IP地址

Router ID选取规则

选取路由器lookback接口上数值最高的IP地址如果没有lookback接口,在物理端口中选择最高IP地址(不推荐,无法保证端口不出现故障)也可以使用router-id命令指定Router ID

路由器角色

指定路由器DR(老大):负责更新其他所有OSPF路由器的信息。备份指定路由器BDR(老二):负责监控备份DR的状态,并在当前DR发生故障时接替其角色。其他路由器DRothers:只和DR及BDR形成邻接关系。

DR和BDR选举方法

自动选举网段上Router ID最大的路由器将选为DR,第二大的为BDR手工选择DR和BDR优先级范围0-255,数值越大,优先级越高,默认为1若优先级相同,则需要对比Router ID大小若路由器的优先级被设置为0,它将不参与DR和BDR的选举

DR和BDR的选举过程

路由器的优先级别可以直接影响选举过程,但是不能强制更换已经存在的DR和BDR路由器的身份。

OSPF的组播地址

224.0.0.5--分发信息给其他的路由器224.0.0.6--接收其他路由器反馈信息

OSPF的度量值为COST

COST=108/BW(带宽),带宽越大,成本越低最短路径是基于接口指定的代价(cost)计算的

OSPF数据包

OSPF数据包承载在IP数据包内,使用的协议号为89

OSPF的包类型

Hello包:用于发现和维持邻居关系,选举DR和BDR。数据库描述包(DBD):用于向邻居发送摘要信息以同步链路状态数据库。链路状态请求包(LSR):在路由器收到包含新信息的DBD后发送,用于请求更详细的信息。链路状态更新包(LSU):收到LSR后发送链路状态通告(LSA),一个LSU数据包可能包含多个LSA。链路状态确认包(LSAck):确认已经收到LSU,每个LSA协议被分别确认。

OSPF的七个状态

Down状态:未收到Hello报文Init状态:收到Hello报文激活启动路由器2-Way状态:选举两个最大的RouterID,但未确认DR和BDR身份

ExStart状态(准启动状态):确认主从路由器(确认DR和BDR身份)Exchange状态:路由器间交换报文(DBD报文和LSAck报文)Loading状态:路由器间除了Hello报文和DBD报文,跑其他的报文(最丰盈状态),如LSR报文、LSU报文Full状态:路由表生成

OSPF的四种类型

点到点网络广播多路访问网络非广播多路访问网络点到多点网络

生成OSPF多区域的原因

1、改善网络的可扩展性2、快速收敛

OSPF的三种通信量

1、域内通信量单个区域内的路由器之间交换数据包构成的通讯量2、域间通信量不同的区域的路由器之间交换数据包构成的通讯量3、外部通信量OSPF域内的路由器与OSPF区域外或另一个自治系统内的路由器之间交换数据包构成的通讯量

OSPF的区域类型

1、骨干区域Area0负责区域间路由信息的传播2、非骨干区域-根据能够学习的路由器种类来区分标准区域末梢区域(stub)完全末梢区域(Totally stubby)非纯末梢区域(NSSA)(三末梢区域内跑不同的LSA)

链路状态数据库的组成

1、每个路由器都创建了由每个接口、对应的相邻节点和接口速度组成的数据库2、链路状态数据库中每一个条目称为LSA(链路状态通告)常见的有六种LSA类型

链路状态通告(LSA)类型

Type 1--路由器LSA:由区域内所有的路由器发出

Type 2--网络LSA:由区域内的DR发出的

Type 3--网络汇总LSA:由ABR发出的,其他区域的汇总链路通告(汇总并交换信息)

Type 4--ASBR汇总LSA:由ABR发出的,用于通ASBR信息,(ASBR相当于外交官)

Type 5--AS外部LSA:由ASBR发出的,用于通告外部路由(4、5是捆绑的,有则全有,无则全无)

Type 7--NSSA外部LSA:由NSSA区域内的ASBR发出的,用于通告本区域连接的外部路由。仅NSSA有Type 7,其他区域都没有Type 7(5、7本质一样,只是存在区域不同)

路由器对路由条目的选择

1、路由器只把最优的路由条目添加到到路由表2、选择路由条目的依据   (1)管理距离   (2)度量值

负载均衡的路由条目

末梢区域和完全末梢区域

满足以下条件的区域

1、只有一个没人路由作为其他区域的出口2、区域不能作为虚链路的穿越区域3、Stub区域里无自治系统边界路由器ASBR4、表示骨干区域Area0

末梢区域

没有LSA4、5、7通告

完全末梢区域

除了一条LSA3的没人路由通告外,没有LSA3、4、5、7通告

路由重分发

1、一个单IP路由协议是管理网络中IP路由的首选方案2、CiscoIOS能执行多个路由协议,每一个路由协议和该路由协议所服务的网络属于同一个自治系统3、CiscoIOS使用路由重发分发特性以交换不同协议创建的路由信息(交换不同协议进程号不同)

重分发到OSPF域中路由的路径类型

类型1的外部路径(Type1 externalpath,E1)类型2的外部路径(Type2 externalpath,E2)

路由器A有两条到达外部目的网落10.1.2.0的路径

E1类型路径A-B-D的代价是25(20+5)(优先)路径A-C-D的代价为48(18+30)E2类型路径A-B-D的代价是20路径A-C-D的代价为18(优先)

NSSA区域是OSPF RFC的补遗

定义了特殊的LSA类型7提供类似stub area 和totally stubby area的特点可以提供包含ASBR

OSPF链路状态通告

LSA 7(NSSA External LSA,NSSA外部LSA) 

NSSA区域重分发路由类型

N1、N2经过NSSA区域ABR后转换为E1、E2

小结

每一种区域中允许泛洪的LSA

OSPF的路径类型的优先级

区域内路径:优先级1区域间路径:优先级2E1外部路径:优先级3E2外部路径:优先级4(1表示最高优先级,4表示最低优先级)

OSPF地址汇总的作用

地址汇总也是通过减少泛洪的LSA数量节省资源可以通过屏蔽一些网络不稳定的细节来节省资源减少路由表中的条目

虚链路

指一条通过非骨干区域连接到骨干区域的链路

虚链路的目的

通过一个非骨干区域连接一个区域到骨干区域通过一个非骨干区域连接一个分段的骨干区域

配置虚链路的规则及特点

虚链路编写配置在两个ABR路由器之间传送区域不能是一个末梢区域虚链路的稳定性取决于其经过的区域的稳定性虚链路有助于提供逻辑冗余
0