概述

GR(Graceful Restart,平滑重启)是一种在主备切换或协议重启时保证转发业务不中断的机制。其核心在于:设备进行协议重启时,能够通知其周边设备,使到该设备的邻居关系和路由在一定时 间内保持稳定。在协议重启完毕后,周边设备协助其进行信息(包括支持GR的相关协议所维护的 各种拓扑、路由和会话信息)同步,在尽量短的时间内恢复到重启前的状态。在协议重启过程中不 会产生路由振荡,报文转发路径也没有任何改变,整个系统可以实现不间断运行。

OSPF GR可以保证运行OSPF协议的路由器在进行主备切换或 OSPF协议重启时,转发业务正常进行。

产生背景

一台路由器的OSPF协议重启之后,会发送 Hello报文以发现邻居,而邻居路由器因为之前已经和 该路由器建立有邻居关系,因此收到该 Hello 报文之后就会把该路由器从邻居列表中删除,断开与 该路由器的邻居关系,并通知其他路由器。当该路由器与邻居路由器重新建立OSPF邻居关系后, 会重新同步所有的路由信息数据,而周边路由器也需要重新进行路由计算,这样就会引起网络的路由振荡以及转发中断,对于一个大型网络,尤其是运营商网络,这些路由振荡和转发中断是不可容忍的。

如何能使协议重启而不引起网络振荡和转发中断呢?由于分布式设备的控制与转发是分开的,主控 板负责整个设备的控制与管理,包括协议运行和路由计算,而接口板则负责数据转发。这样当发生 主备倒换或协议重启时,数据转发仍然可以不中断进行。同时,如果在重启期间周边设备能维持邻居关系不变并保持路由稳定,并且在设备重启后能协助设 备进行路由信息同步,在尽量短的时间内使得本设备的路由信息恢复到重启前的状态,那么就可以 保持网络拓扑稳定,不引起网络路由振荡。

为了实现这个目的,OSPF 路由协议进行了扩展,即OSPF GR。通过 OSPF GR,可以避免网络 的路由振荡及转发中断。

技术优点

保证协议重启或主备切换过程中转发业务不中断

减少协议重启或主备切换时路由振荡对全网的影响

减少单点故障,提高整个网络的可靠性

OSPF GR技术详细介绍

概念介绍

OSPF GR的基本术语:

GR Restarter:发生协议重启事件且具有 GR能力的设备。

GR Helper:和 GR Restarter具有邻居关系,协助完成 GR流程的设备。

GR Session:OSPF邻居建立时进行关于 GR能力的协商,一般把 GR能力协商过程称为 GR Session。协商的内容包括双方是否都具备 GR能力等。一旦 GR能力协商通过,当协议重启 时就可以进入 GR流程。

说明:分布式设备可以充当 GR Restarter和 GR helper;而集中式设备只能充当 GR Helper,协助 GR Restarter完成 GR流程。

目前 H3C有两种方式实现 OSPF GR技术:

一种是基于 IETF标准,Restarter通过向 Helper发送一种称为 Grace LSA(Link state advertisement,链路状态信息公告)的 9类 Opaque LSA来控制 GR的交互过程。

另外一种是非 IETF标准,Restarter与 Helper之间是通过相互发送携带 LLS(Link local signaling,本地链路信令)与 OOB(Out-of-band LSDB Resynchronization,带外的链路状 态信息库重新同步)扩展信息的 OSPF报文来完成 GR的交互过程。

说明:GR Restarter上只能配置 IETF标准与非 IETF标准其中的一种能力,两种方式是互斥的。

IETF标准OSPF GR实现机制

对 OSPF协议做了如下扩展:增加一种 9类 Opaque LSA――Grace LSA,用以在 GR Restarter 重启时,通知周边邻居进入** GR Helper**流程。

Grace LSA

Grace LSA格式如图 1所示。

图1 Grace LSA格式

其中,几个主要的 TLV 的含义如下:

Grace Period TLV:Type 取值为 1,长度为 4字节,表示邻居设备进入 GR Helper处理流程 的最长保持时间。如果超过这段时间 GR Restarter还没有完成 GR处理流程,则周边邻居不 再担任 GR Helper角色。该 TLV 是 Grace LSA必须携带的。

Graceful Restart Reason TLV:Type 取值为 2,长度为 1字节,告知邻居设备 GR Restarter 的重启原因。Value取值为0表示原因未知,取值为1表示软件重启,取值为2表示软件重新 加载(升级),取值为 3表示 GR Restarter进行主备倒换。Grace LSA中必须携带该 TLV。

IP Interface Address TLV:Type 取值为 3,长度为 4字节,用来告知发送 Grace LSA的接口 的 IP地址,在网络上需要用该 IP地址来唯一标识一台重启设备。

IETF标准 OSPF GR运行过程

如图 2所示,假设 Router A和 Router B原来有稳定的OSPF邻居关系,并且 Router A使能了 GR 能力,此时 Router A重启,将按照以下的流程进行路由信息交互:

1.Router A重启之后向 Router B发送 Grace LSA。

2.Router B收到 Router A发出的 Grace LSA后,会维持与 Router A的邻居关系不变。

3.Router A与 Router B进行 Hello报文与 DD(Database Description,链路状态信息库描述) 报文交互和 LSDB同步。由于 GR 过程中不能生成 LSA,所以在 LSDB同步过程中,如果 Router A从 Router B收到自己产生的 LSA,直接存储下来并置上 Stale标志。

4.完成 LSDB的同步之后,Router A发送 Grace LSA(Grace Period TLV的 Type值为 0)通 知 Router B结束 GR 流程。Router A进入正常 OSPF流程,然后 Router A重新生成 LSA, 并删除那些置了 Stale标志而又没有被重新生成的 LSA。

5.Router A在恢复所有路由信息后重新进行路由计算,重新刷新 FIB表。

图2 IETF标准 OSPF GR运行示意图

非IETF标准OSPF GR实现机制

与IETF标准的OSPF GR相比,非IETF标准GR主要是通过下面两个能力扩展来支持OSPF GR:

Link-Local Signaling:OSPF本地链路通告扩展,用来标识当前路由器和其他路由器进行一 些可选信息的通信。

Out-of-band LSDB Resynchronization:带外的 LSDB重新同步,完成无邻接关系变化的 LSDB重新同步。

LLS能力扩展

在OSPF的Hello报文和DD报文的尾部增加了LLS Data。同时对Hello报文和 DD报文的Option字段进行扩展,以标识是否携带LLS。扩展后的Option字段如图 3 所示,如果L位置1表示携带了LLS Data。

图3 Option字段

经过扩展后的报文格式如图 4所示。

图4 LLS扩展后的 OSPF 报文格式图

LLS Data的具体的格式如图 5所示。

图5 LLS Data字段

LLS Data中的 TLV 可以用于进行不同的 OSPF扩展。例如为支持 GR,使用了类型为 1的 TLV, 即 Extended Option TLV(EO TLV)。下面我们讲一下 EO TLV 里两个重要字段:

LR字段:用以实现 OOB能力的协商,LR在 EO TLV 中的位置如

图 6所示。如果当前路由器 具备 OOB能力,则在发送 Hello和 DD报文时将 LR(LSDB Resynchronization)进行置位;否则不对 LR进行置位。

图6 EO TLV LR位说明图

RS字段:用以通知邻居当前路由器进入 GR流程,RS在 EO TLV 中的位置如图 7所示。当 路由器需要短暂离开网络时,可以通过将 Hello报文中的 RS(Restart Signal)置位来向周边 邻居通知自己需要进入 GR流程,这样周边邻居就会保持与此路由器的邻居关系不变;否则不 对 RS进行置位。

图7 EO TLV RS位说明图

OOB能力扩展

当路由器通过 LLS 完成 OOB 能力协商,确认双方都具备 OOB 能力后,则表示可以在邻居关系和 网络拓扑稳定时进行LSDB同步,即进入OOB流程。这时需要在向邻居发送的DD报文中将Option 字段中的 R进行置位,R在 Option字段中的位置如图 8所示。

图8 DD报文

非 IETF标准 OSPF GR运行过程

如图 9所示,假设 Router A和 Router B原来有稳定的 OSPF邻居关系,并且 Router A使能了 GR 能力,此时 Router A重启,将按照以下的流程进行路由信息交互:

1.Router A重启后向 Router B发送 LR和 RS都置位的 Hello报文,向 Router B通告自己只是 暂时断开马上就会恢复正常,并且自己具备 OOB能力;

Router B收到Hello报文后,也会向Router A回复一个LR仍保持置位但是RS位已经清除的 Hello报文,向 Router A通告自己已经知道它是要短暂离开,并且自己也具备 OOB能力;

2.Router A向 Router B发送 R置位的 DD报文,向 Router B发起 LSDB同步请求,在 LSDB 同步期间,Router B不会将 Router A从自己的邻居列表中删除,在自己生成的 Router LSA (Network LSA)中,与 Router A的邻居关系仍然为 Full。由于 GR 过程中不能生成 LSA, 所以在 LSDB同步过程中,如果 Router A从 Router B收到自己产生的 LSA,直接存储下来 并置上 Stale标志。

3.完成LSDB的同步之后,Router A结束GR流程,进入正常OSPF流程,然后Router A重新 生成 LSA,并删除那些置了 Stale标志而又没有被重新生成的 LSA。Router B在和 Router A 的邻居关系重新达到 Full状态后退出 GR流程,进入正常 OSPF流程。

4.Router A在恢复所有路由信息后重新进行路由计算,重新刷新 FIB表。

图9 非 IETR标准 GR 同步过程

典型组网应用

OSPF GR典型组网应用

组网图

图10 OSPF GR配置组网图

组网需求

Router A、Router B、Router C、Router D、Router E、Router F、Router G、Router H、 Router I、Router J、Router K、Router L运行 OSPF协议。

Router A、Router B与骨干网相连,属于骨干节点。

Router G、Router H、Router I、Router J、Router K、Router L是分支节点,通过核心节点 Router C、Router D、Router E与骨干节点相连,通过骨干节点连接到骨干网上。

使用 GR保证网络中的骨干节点和核心节点在出现协议重启时的转发业务不中断,避免出现不 必要的路由振荡。

骨干节点和核心节点作为 GR Restarter(同时缺省也作为 GR Helper),分支节点作为 GR Helper。这样当骨干节点发生主备切换或重启 OSPF进程时,核心节点可以作为 GR Helper 协助其进行 LSDB重同步,并且保持转发不中断;当核心节点发生主备切换或重启 OSPF进 程时,骨干节点和分支节点都可以作为 GR Helper协助其进行 LSDB重同步,并且保持转发不中断。

oracle tlv,OSPF GR(Graceful Restart,平滑重启)技术相关推荐

  1. 平滑重启更新(GR机制)

    什么是平滑启动机制 是一种在协议重启时保证转发业务不中断的机制. 什么时候用到平滑重启 平滑重启一般应用于业务更新或者版本发布过程中,能够避免因为代码发布重启服务导致的暂时性服务不可用的影响. ngn ...

  2. supervisor 重启_Golang HTTP服务平滑重启及升级

    Golang HTTP服务在上线时,需要重新编译可执行文件,关闭正在运行的进程,然后再启动新的运行进程.对于访问频率比较高的面向终端用户的产品,关闭.重启的过程中会出现无法访问(nginx表现为502 ...

  3. 华为设备配置OSPF GR特性

    配置各接口所属的VLAN [LSW1]vlan batch 10 [LSW1-GigabitEthernet0/0/2]port link-type trunk [LSW1-GigabitEthern ...

  4. Golang服务平滑重启

    与重载配置相同的是我们也需要通过信号来通知server重启,但关键在于平滑重启,如果只是简单的重启,只需要kill掉,然后再拉起即可.平滑重启意味着server升级的时候可以不用停止业务. 我们先来看 ...

  5. php fpm 平滑重启,nginx、php-fpm平滑重启和重载配置

    nginx 相对而言,nginx前后版本对于重启以及重新加载配置的改变不大,其进程分为master主进程和worker工作进程.master进程通过信号通知worker进程执行工作.通过简单操作命令 ...

  6. 【博客567】http/2 goaway frame 与 grpc graceful restart

    http2 goway frame 与 grpc graceful restart 1.http/2 HTTP/2新增特性 二进制分帧(HTTP Frames) 多路复用 头部压缩 服务端推送(ser ...

  7. Go项目实现优雅关机与平滑重启

    Demo快速上手 优雅关机 package mainimport ("context""github.com/gin-gonic/gin""log&q ...

  8. Go实现优雅关机与平滑重启

    前言 优雅关机就是服务端关机命令发出后不是立即关机,而是等待当前还在处理的请求全部处理完毕后再退出程序,是一种对客户端友好的关机方式.而执行Ctrl+C关闭服务端时,会强制结束进程导致正在访问的请求出 ...

  9. Nginx 的启动、停止、平滑重启、信号控制和平滑升级

    Nginx 的启动          假设 nginx 安装在 /usr/local/nginx 目录中,那么启动 nginx 的命令就是: [root@localhost ~]# /usr/loca ...

最新文章

  1. 又改ResNet | 重新思考ResNet:采用高阶方案的改进堆叠策略(附论文下载)
  2. java兩個矩陣相乘_Day12 練習java-矩陣乘法
  3. cookie在后台的存取
  4. php判断几维数组的方法,php如何判断数组是几维
  5. defer func(参数){}
  6. php语言难点,PHP知识难点TOP3,挑战一下你
  7. Delphi关于多线程同步的一些方法
  8. 局域网服务器文件夹隐藏,局域网服务器共享文件夹访问权限设置win7隐藏无权限共享文件夹方法.docx...
  9. MySQL表的非外键约束
  10. [Matlab] 符号积分求对流扩散方程在给定初始条件下的一维解
  11. 用python爬取知识星球
  12. 【转】linux /centos 中OpenSSL升级方法详解
  13. VisualStudio异常处理 —— LNK1112 模块计算机类型“x64”与目标计算机类型“X86”冲突
  14. Android利用soap WSDL与Webservice通信
  15. C#绘图双缓冲技术总结(转)
  16. python画正方形并涂色_关于python使用cv画矩形并填充颜色同时填充文字
  17. 电熨斗IEC测试流程及周期
  18. 【教程】InstallShield使用完全教程
  19. OpenCV创始人Gary Bradski,现已加入蓝胖子机器人
  20. QT应用编程: 获取系统当前时间以及1970到现在的总秒数

热门文章

  1. 个人项目部署至腾讯云服务器 用ip或者域名直接访问 详细步骤及注意点! 适合新手
  2. Hibernate笔记+相关面试题
  3. (深度神经网络多.py文件)python打包过程遇到的问题记录
  4. vue实现用户登录验证 + 权限验证 + 动态路由(左侧菜单栏)
  5. 排列组合_均匀分组和部分均匀分组的计算与示例/二项式定理二项式系数/求和中的对称性/莱布尼兹公式与推广的求导法则
  6. mac如何在Finder中显示隐藏的文件或文件夹
  7. java yyyy-mm-ddthh:mm:ssz,获取录音文件下载地址接口
  8. 微信订阅号简单开发指引
  9. 帆软10.0 冻结行 冻结列的 点击行变色
  10. ubuntu下安装Realtek usb无线网卡驱动(8821cu)