IGP高级特性简要介绍(OSPF-上篇)

OSPF高级特性

一、OSPF_提升故障收敛及网络恢复速度

1.FRR与BFD快速恢复故障

1.1 FRR

在传统转发模式下,当到达同一个目的网络存在多条路由时,路由器总是选择最优路由使用,并且下发到FIB表指导数据转发。

当最优路由故障时,需要等待路由收敛完成重新选路,然后再把优选路由下发到转发表,业务才能恢复。

在这个过程中,业务中断时间较长,不能满 足业务的要求。

为此FRR快速重路由(Fast Reroute)就提供了解决方案:其核心就是找到一个在主用链路故障后的下一跳邻居节点,如果这个邻居节点目的节点最短路径不经过源节点,则这个邻居节点为无环备份下一跳。

源节点:源
邻居节点:源节点的相邻节点
目的节点:目的

通俗介绍:

在这里插入图片描述

案例:

​ 1、无FRR情况下查看4.4.4.4路由信息,只能看到一个下一跳。

在这里插入图片描述

​ 2、如果启用了FRR功能,将会出现BkNextHop备份下一跳,当主下一跳故障之后将立即切换到由FRR计算的备用链路转发数据。
在这里插入图片描述

反转:虽然是具备了备用转发路径,但前提是感知到链路故障之后才会进行切换,如果设备无法快速感知到链路故障,那么实际上还是存在丢包过多的情况。

​ 比如下面这种情况可能会造成设备无法快速感知链路故障:

​ 该结果就是,AR1需要等待40秒的超时时间才能感知到与AR2之间的链路存在故障。因此就非常需要另一项技术进行快速的故障感知(BFD
在这里插入图片描述

FRR的配置

OSPF进程中开启frr并使用LFA算法进行计算无环下一跳
ospf 1frrloop-free-alternate
1.2 BFD

BFD(Bidirectional Forwarding Detection,双向转发检测),提供了一个通用的标准化的介质无关协议无关的快速故障检测机制,用于快速检测、监控网络中链路或者IP路由的转发连通状态。

(1)BFD如何实现快速感知故障的呢?

​ BFD通过静态动态的方式建立起BFD会话,并在极短的时间内相互发送BFD报文,如果对方在一定时间内没有回复BFD报文,则BFD会话状态将变成Down表示出现故障。

(2)BFD如何与FRR配合解决故障快速收敛?

​ 以OSPF为例,FRR计算出备份下一跳之后,只要当原先链路断开之后才会快速切换至备份下一跳。当设备无法快速感觉到链路发生故障时,只能等待40秒邻居老化之后才会进行切换。

​ 为此使用BFD与邻居自动建立会话实现故障快速检测,实现当链路断开之后的3秒钟BFD会话断开。

​ 因为BFD与OSPF进行联动,故当BFD会话断开之后,其相应的OSPF邻居关系也会同时断开,从而实现链路故障后的快速切换。

(3)如何应用BFD?

​ 全局启用BFD功能之后,通过静态或动态方式建立起BFD会话,然后将其与OSPF、ISIS等路由协议进行联动,实现网络故障后的快速感知。

例子1:OSPF与BFD联动

# 全局开启BFD功能
[Router] bfd# 进程中应用BFD功能
[Router] ospf 1
[Router-ospf-1] bfd all-interfaces enable# 默认BFD发送和接收间隔均为1秒,丢包3次则为故障,即BFD对端故障后3秒将会检测到。
# 若想继续提高检测速度,可将发送和接收间隔缩短至 500毫秒,即1.5秒后检测到故障。
# 发送间隔
[Router-ospf-1] bfd all-interfaces min-tx-interval 500
# 接收间隔
[Router-ospf-1] bfd all-interfaces min-rx-interval 500

例子2:BFD与ISIS联动

[Router] bfd
[Router-bfd] quit[Router] isis
[Router-isis-1] bfd all-interfaces enable
[Router-isis-1] quit

:详细介绍与案例于后面章节1.1.0 IGP高级特性之BFD 中继续介绍

2.OSPF的智能定时器 加速网络收敛

2.1 RPC

(Partial Route Calculation,部分路由计算)

​ 当网络上“路由”发生变化的时候,只对发生变化的路由进行重新计算,RPC不计算节点路径,而是根据SPF算法算出来的最短路径树来更新路由。

​ 因为只有“路由”变动,即拓扑本身没有变,变的只是最外边的“树叶”。

如下图:不管R5增加了多少个路由,只要没有影响原先计算好的“拓扑”结构,均可新增入网络中。新增之后R5会向其它节点通告新网络接入。

在这里插入图片描述

2.2 I-SPF

(Incremental SPF,增量最短路径优先算法)

​ 当网络拓扑改变的时候,只针对受影响的网络节点进行“路由”和“拓扑”计算,而不是全网节点重新进行路由计算。

如下图:当R5节点下接入新节点R6,那么R5将会把R6新接入的信息通告给其它节点,而其它节点只需要把R6节点在原先计算好的拓扑上增加即可。

在这里插入图片描述

2.3 智能定时器

​ 在进行SPF计算和产生LSA的时候会使用到的特殊定时器,他控制着SPF的计算,LSA的更新速度和接收速度,从而加快和减缓网络受影响的时间。

​ 如下图:智能定时器的作用

在这里插入图片描述

2.4 智能定时器的介绍与设置

(1)设置LSA接收的间隔,间隔内不接收LSA,间隔后再接收:

默认:接收LSA的最长间隔时间为1000毫秒、初始间隔时间为500毫秒、基数间隔时间为500毫秒

lsa-arrival-interval intelligent-timer 最长间隔 初始间隔 基数间隔

(2)设置LSA更新的间隔,间隔内不更新LSA,间隔后再更新:

默认:更新LSA的最长间隔时间为5000毫秒、初始间隔时间为500毫秒、基数间隔时间为1000毫秒

lsa-originate-interval intelligent-timer 最长间隔 初始间隔 基数间隔

(3)设置路由计算的间隔,间隔内不计算LSA,间隔后再计算:

默认:SPF计算的最长间隔时间为10000毫秒、初始间隔时间为500毫秒、基数间隔时间为1000毫秒

spf-schedule-interval intelligent-timer 最长间隔 初始间隔 基数间隔

注解:三个间隔的表示的含义

  1. 初次更新LSA的间隔时间由初始间隔参数指定。
  2. 第n(n≥2)次更新LSA的间隔时间为 基数间隔×2^(n-2)。
  3. 基数间隔×2^(n-2) 达到指定的最长间隔时,OSPF连续3次更新LSA的时间间隔都是最长间隔时间之后,再次返回按照初始间隔时间更新LSA,如此反复。

举例:

更新LSA的最长间隔时间为5000毫秒、初始间隔时间为500毫秒、基数间隔时间为1000毫秒。

​ 设备接入OSPF网络建立邻居关系之后(因为邻居建立后才交互LSA等信息),先等待500ms的初始间隔,收集网络中其它节点的LSA信息,500ms结束后才能发送自己的LSA信息。

​ 第1次更新LSA间隔:初始间隔的500ms

​ 第2次更新LSA间隔:1000ms*2^(2-2)=1000ms*1,1000ms后才可更新LSA,1000ms内即使有网络变更也不更新。

​ 第3次更新LSA间隔:1000ms*2^(3-2)=1000ms*1,2000ms。

​ 第4次更新LSA间隔:1000ms*2^(4-2)=1000ms*4,4000ms。

​ 第5,6,7次更新LSA间隔:1000ms*2^(5-2)=1000ms*8,但最长间隔为5000ms,故5、6、7次均为5000ms。

​ 第8次更新LSA间隔:由于连续3次更新均为最长间隔,重置到初始间隔的500ms。

有个很核心的问题,这里所说的更新、接收、计算的LSA是什么?

指的就是OSPF的那1、2、3、4、5、7类等LSA

3.延迟收敛

OSPF的收敛时间相对较快,在不计算LSA同步时间下,广播类型接口建立邻居后40秒选举完DR、BDR才会进入邻接关系,而如果是点对点类型接口则会更快建立起邻接关系。

默认情况下,在不计算路由同步时间下,BGP进入Established状态需要32秒。从TCP建立成功后的Active状态到Established这32秒的延迟(重传定时器)是为了确保网络稳定性,避免因快速切换或网络波动而导致的不稳定情况。

故,如果在BGP网络中使用的IGP协议为OSPF,接口类型为点对点,那么就会出现网络故障后又恢复之时,由于OSPF网络优先收敛完成,而BGP未完成路由同步造成数据包丢失。

3.1 图文解释P1

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.2 图文解释P2

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.3 解决方法

为了防止这种情况出现,通过在OSPF上配置命令:

(1)stub-router

启用之后,默认将该路由器传递的路由度量值设为最大(65535),从而控制其它节点路由器避免数据从此路由器转发。
@未选择on-startup参数,则表示该路由器始终保持为Stub设备,即所有来自这个路由器的路由条目Cost值均设为65535。

(2)stub-router on-startup 恢复时间

表示该路由器仅在重启或者主备倒换时保持为Stub设备,恢复时间结束之后才会恢复成正常的设备。
只有当到达了时间之后,才会将链路切换回来,反之,继续保持之前的状态。
从而避免出现BGP路由黑洞的情况。

(3)ISIS中实现相同效果则是用它独有的超载特性,然后加上on-startup命令选项,控制设备恢复时间。

set-overload on-startup 恢复时间

4.GR平滑重启

​ 路由设备采用了控制转发分离的技术之后(转控分离),在网络拓扑保持稳定的情况下,控制层面的重启并不会影响转发层面,转发层面仍然可以很好地完成数据转发任务,从而保证业务不受影响。

控制层面:接收处理协议信息,如路由表。
转发层面:负责数据报文转发,如转发表。

在这里插入图片描述

​ GR(Graceful Restart 平滑重启)技术,属于RFC 3623,该技术保证设备在重启过程转发层面能够继续指导数据的转发,同时控制层面邻居关系以及路由计算等动作不会影响转发层面的功能(重启过程中其它邻居感知不到该设备正在重启),从而避免了路由振荡引发的业务中断,提高了整网的可靠性。

4.1 GR的工作原理
GR实现

​ 1、与重启设备建立OSPF邻居的设备均需要具备GR功能,否则在设备重启之后,会与该邻居断开关系造成网络震荡。

​ 2、在GR中重启设备称为GR Restarter、其邻居叫作GR Helper

​ 3、GR报文即Grace-LSA属于9类LSA,只能在接口网段中泛洪,因此不会在网络中大量泛洪。

​ 4、GR报文用于在开始GR退出GR时向邻居通告GR的时间、重启原因以及接口地址等内容。

​ 5、其配置命令只有核心的两条:

[OSPF进程中执行]# 使能设备可以生成和处理9类LSA报文
opaque-capability enable# 使能OSPF GR功能
graceful-restart

​ 6、其中关于graceful-restart的默认参数如下:

参数参数说明取值
period period指定平滑重启的周期。整数形式,取值范围是1~1800,单位是秒。缺省值是120秒。
planned-only指定路由器仅支持Planned GR。
缺省情况下,路由器支持Planned GR和Unplanned GR。
-
partial指定路由器支持Partial GR。
缺省情况下,路由器支持Totally GR。
-
GR“主动倒换”工作的过程

​ 1、GR Restarter设备主动进行倒换,倒换前向邻居发送GR(Grace-LSA)报文通告自己将要重启,请不要删除与我之间的邻居关系。

注意,倒换前发送GR报文的次数不定,依厂商而定,华为手册写的是倒换前只发送一个GR报文。

​ 2、邻居GR Helper 收到GR报文之后,保证GR Restarter重启中邻居关系依旧保留,同时回复LSAck确认收到对方的GR报文。

此时GR Restarter设备是否收到LSAck都无所谓了,只要GR Restarter设备发送的GR报文被GR Helper收到即可。

​ 3、当GR Restarter设备恢复正常之后,再次发送GR报文通知GR Helper,然后开始进行同步LSDB 。

网络类型接口建立邻居时需要经过40秒选举DR/BDR,但由于先前已经通过GR报文同步了部分OSPF信息,故当GR Restarter设备收到GR Helper的Hello报文之后,将马上进入Exstart状态开始同步LSDB。

​ 4、当同步完成之后,通过发送Flush Grace-LSA报文(Age为3600秒的GR LSA),GR Restarter设备可以向GR Helper和其他路由器设备发出一个明确的信号,表示自己已经恢复了正常的运行状态。

为啥需要这个FlushGR报文呢,有何用意?

因为自GR Restarter发送GR报文给GR Helper之后,GR Helper们均一直在维持着与GR Restarter的邻居信息,即一直处于GR Helper状态下。所以在设备恢复之后,为了减少设备负担,通过发送Flush GR报文来终止这种关系。

当然也存在一个定时器,GR的持续时间最长为1800秒,当超过这个时间之后,GR的这种关系也会自动断开,之所以为1800是为了避免重新启动路由器的LSA老化(LSA老化时间)。

下图举例与其中某一台OSPF邻居交互GR报文过程:

在这里插入图片描述

GR“被动倒换”工作的过程

​ 1、设备因突发故障导致设备需要断电重启。

​ 2、Restarter设备重新启动之后,需要先向所有接口发送多次GR报文(目的224.0.0.5)

华为中重新启动后会连续发送5次GR报文。

在广播网络上,由于重新启动的路由器不知道其先前的DR状态,因此必须将此GR LSA泛洪到所有路由器。

​ 3、至此,手册与RFC就没有下文了。至于是重新建立OSPF邻居还是怎样,不知道咯。

因为在没有发送GR报文给Helper的情况下,突然重启设备,那么邻居状态固然会断开。

重启完成之后,再发送GR报文的意义是什么呢?

关于GR技术的疑惑点

​ 1、GR设备配置完成之后,如何实现所谓的计划重启?

reboot?还是其它专用重启命令?均没有在手册与RFC中出现。

​ 2、GR突发故障后设备重启如何恢复的过程没有明确讲到。

5.NSF/NSR不间断转发/不间断路由

NSF与NSR的区别

​ NSF(Non-Stopping Forwarding)不间断转发

​ NSR(Non-Stopping Routing)不间断路由
在这里插入图片描述

两者的应用场景

​ 当网络对丢包的要求、对路由收敛的速度的要求都比较低时,可以使用NSF功能。

​ 当网络对丢包的要求、对路由收敛的速度的要求都比较高时,可以使用NSR功能。

两者的优缺点
类型NSRNSF
硬件NSR需要配置两块主控板。一块做主用主控板,处于工作状态;一块做备用主控板,处于备份状态。当主用主控板重启时,备用主控板成为新的主用主控板。
NSR需要数据转发和控制分离,除主控板之外有专门的接口板用于数据转发。
主控板主要运行控制层的软件,比如动态路由协议;主控板用于学习和维护路由表,并计算出路由转发表FIB(Forwarding Information Base),使用接口板进行数据转发。
接口板负责根据主控板计算出的转发表进行数据的转发。
跟NSR的要求相同。
软件主用主控板正常运行的过程中,会把配置信息、接口状态信息、协议状态信息备份到备用主控板。当主用主控板因为硬件或者软件失效出现故障时,备用主控板接管失效的主用主控板的工作,重新启动控制层和转发层。跟NSR的要求相同。
协议无特殊要求。各相关网络协议,路由协议如OSPF、IS-IS、BGP等,其他协议如LDP、RSVP等做扩展,需要具备GR技术的能力。
优点NSR无需通知邻居节点路由信息变化,同时也无需邻居节点的协助。
当多个节点的控制层同时故障时,系统运行情况仍在在可控范围内。
当故障恢复时,短时间内即可恢复数据,且在主备切换中,网络拓扑也能够恢复。
当系统正常运行时,NSF对系统的负荷较小,系统性能较高。
缺点当系统正常运行时,NSR对系统的负荷较大,系统性能相对较低。
系统软件异常时NSR将失效。
需要邻居节点同样具备NSF能力,且需要部署在整网中。当多节点的控制层均故障时,NSF将失效。当故障恢复时,需要花费较长时间恢复数据,且网络拓扑的恢复也相对缓慢。网络拓扑的变化或者接口状态的变化,可能导致NSF失效。
NSR的工作原理

​ NSF的实现过程其实就是通过GR功能进行实现。

​ 原理主要包括以下三个过程:

  1. 批量备份:NSR功能使能后,备板复位重启过程中,主用主控板将路由信息和转发信息批量备份到备用主控板上。批量备份过程一定是在实时备份过程之前进行,同时NSR还不具备主备倒换能力。
  2. 实时备份:当批量备份过程结束后,系统进入实时备份阶段。任何在控制平面和转发平面的改变都将实时从主用主控板备份到备用主控板上。在该阶段,备用主控板能够随时代替主用主控板工作。
  3. 主备倒换:在已经完成备份的NSR系统主用主控板发生故障时,备用主控板会通过硬件状态感知到主用主控板故障,并成为新的主用主控板。备用主控板成为新主用后,会自动切换接口板的报文上送通道到新主控板。由于倒换时间足够短,路由协议在主备切换的过程中不会和邻居节点断连。

在这里插入图片描述

NSF与NSR的命令实现
# NSR能够实现路由处理及转发业务不中断
switchover mode nonstop-routing# NSF能够大幅减少转发业务中断时间
switchover mode nonstop-forwarding# 查看当前系统HA的工作模式
display switchover mode

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/164120.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity 实现文字过长显示省略号

为了整体效果,当文字过长时,我们就会把超出范围的文字弄成省略号。 要实现文字过长显示省略号,只需要使用TextMeshPro,并设置Overflow属性为Ellipsis即可。 如下图: 记。

高并发下Redis缓存与数据库双写一致性问题原理分析和解决方案

目录 一、什么是缓存与数据库双写不一致性二、常见保证高并发下双写一致性方案2.1、延迟双删(不可靠)2.2、分布式读写锁(可靠)2.3、MQ异步消费(不可靠)2.4、订阅数据库变更日志(不可靠&#xff…

机器视觉软件破解的背后是道高一尺,魔高一丈

讲个故事,小明从某购物平台花2000元买了一个C#机器视觉架构,压缩包带加密,卖家让小明先确认收货后给密码。 小明花了3元从另外一家卖家破解开压缩包密码,然后迅速从第一家卖家退货。小明成功省了1997元。 “道高一尺&#xff0c…

使用Android Jetpack Compose渲染效果打造酷炫的动画效果

如何在Android Jetpack Compose中使用渲染效果打造令人惊艳的视觉体验 学习示例:如何使用渲染效果来改变UI界面 引言 Jetpack Compose提供了各种工具和组件来构建引人入胜的UI,而在Compose中较为鲜为人知的一个宝藏是RenderEffect。 在这篇博文中&a…

操作系统引论(二)

操作系统发展动力及技术基础 推动操作系统的发展和资源利用率的提高是相关联的。 让输入输出相对独立,通道技术,通道相当于简单的处理器,通过输入输出指令,控制外设完成输入输出。 输入和输出过程不是由主机控制的,是…

【深度学习】pytorch——神经网络工具箱nn

笔记为自我总结整理的学习笔记,若有错误欢迎指出哟~ 深度学习专栏链接: http://t.csdnimg.cn/dscW7 pytorch——神经网络工具箱nn 简介nn.Modulenn.Module实现全连接层nn.Module实现多层感知机 常用神经网络层图像相关层卷积层(Conv&#xff…

Flink--Data Source 介绍

Data Source 简介 Flink 做为一款流式计算框架,它可用来做批处理,即处理静态的数据集、历史的数据集;也可以用来做流处理,即实时的处理些实时数据流,实时的产生数据流结果,只要数据源源不断的过来&#xff…

「Verilog学习笔记」多功能数据处理器

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点,刷题网站用的是牛客网 分析 注意题目要求输入信号为有符号数,另外输出信号可能是输入信号的和,所以需要拓展一位,防止溢出。 timescale 1ns/1ns module data_…

Java 正则表达式分组匹配

前几篇文章都是简单判断是否满足匹配规则,当需要提取匹配结果时就用到分组匹配。 分组匹配 可以判断是否满足正则表达式,然后提取出子串。 有些时候电话号码是以 123-4567-8899 这样显示的,我们要判断某个字符串是这种形式的并分别提起三段…

Redis 扩展 RedisBloom 插件,解决缓存击穿、穿透

文章目录 一、概述二、编译准备2.1 升级 make2.2 安装 Python3 三、编译 RedisBloom四、测试 RedisBloom五、应用场景5.1 缓存击穿5.2 缓存穿透5.3 原理总结 六、存在的问题 如果您对Redis的了解不够深入请关注本栏目,本栏目包括Redis安装,Redis配置文件…

两个栈实现队列

要用两个栈实现队列,就需要了解栈和队列的特性,栈是先进后出,队列是先进先出。基本思路是,把数据先压入栈1中,然后数据在栈1中输出再压入栈2,输出后就能实现队列的先进先出。 package Package;import java.…

SPASS-数据收集及预处理

统计数据的收集 问卷设计 问卷构成 (1)标题 (2)导语(前言) (3)正文 (4)结束语 问卷的问题类型 (1)封闭型问题 (2&…