学习笔记——动态路由——OSPF(工作原理)

九、OSPF协议的工作原理

1、原理概要

               

(1)相邻路由器之间周期性发送HELLO报文,以便建立和维护邻居关系

(2)建立邻居关系后,给邻居路由器发送数据库描述报文(DD),也就是将自己链路状态数据库中的所有链路状态项目的摘要信息发送给邻居路由器

(3)收到数据库描述报文后,若发现自己缺少其中某些链路状态项目,则会发送链路状态请求报文(LSR)

(4)对方收到链路状态请求报文后,则会将其所缺少的链路状态项目的详细信息封装在链路状态更新报文(LSU)中发送回去

(5)收到链路状态更新报文后,将这些信息添加到自己的链路状态数据库中,随后发回链路状态确认报文(LSAck)

(1)HELLO协议

1)发现邻居并监测与邻居链路的状态

OSPF路由器定期向所有邻居路由器发送HELLO报文。报文中包含了最近一段时间内发送过HELLO报文的邻居路由器。

发送周期为10秒40秒未收到来自邻居路由器的HELLO报文,则认为该邻居路由器不可达

如果路由器在邻居发送的HELLO报文中发现了自己的标识符,就表明这两个邻居路由器之间建立了双向通信链路。每个路由器都会建立一张邻居表。

HELLO协议在不同类型网络上的工作过程不同:

点到点网络、虚拟链路:路由器向对方发送HELLO报文;

点到多点网络:路由器仅向能直接通信的邻居发送HELLO报文;

广播网络:每台路由器定期组播发送HELLO报文;

NBMA网络:需要配置后HELLO协议才能正常工作。

2)DR/BDR的选举

广播网络或NBMA网络上每台路由器都清楚网络的链路状态。若每台路由器都发送网络的链路状态,会有很多重复发送。

OSPF协议规定:

在广播网络或NBMA网络上选举一个指定路由器(DR)和一个备份指定路由器(BDR)。

只有DR能代表该网络发送网络的链路状态,DR发生故障后,BDR就变成DR。

当路由器连接到广播网络或NBMA网络上的接口启动时,(下左图)检查该网络上是否已存在DR和BDR:存在就接受;否则,比较自己和其他路由器的优先级:

- 优先级最高的路由器成为DR;优先级次高的路由器成为BDR。优先级:0-255,默认值是1

- 若两个路由器的优先级相同,标识符(ID)更大的胜出。

DR和BDR一旦选定,即使OSPF区域内新增优先级更高的路由器,DR和BDR也不重新选举。(下右图)

(2)链路状态数据库同步

OSPF邻接路由器之间的链路状态数据库同步大体上可分为三步:

1)双方交换各自的链路状态数据库摘要

2)向对方请求链路状态并更新自己的数据库

3)若有链路的状态发生变化,更新自己的数据库,并通知对方

1)交换摘要

OSPF路由器定期与邻接路由器交换链路状态数据库摘要:

数据库摘要用一组数据库描述报文描述;

每个数据库描述报文包含一组链路状态通告(LSA)的首部;

LSA首部有其唯一标识及新旧标记。

2)同步信息

发送和接收数据库描述报文的过程称为“数据库交换过程”,其中:

路由器发现邻接路由器某些链路的状态更新,或自己没有,就向对方发送链路状态请求报文;

邻接路由器发送链路状态更新报文进行响应。

两个邻接路由器的链路状态数据库达同步后,称它们之间建立了完全邻接关系(fully adjacent)。

3)新情况下的同步

路由器监测其所有链路,若有链路的状态发生改变:

更新自己的链路状态数据库;

向邻接路由器发送链路状态更新报文,通知变化的链路状态。

4)洪泛机制

OSPF协议定义了一种可靠的洪泛(reliable flooding)机制,用于在OSPF路由域中快速扩散链路状态的变化。

可靠是指收到链路状态更新报文后要发送确认,收到重复的更新报文无需再次转发,但要发送一次确认。

路由器接收到链路状态更新报文后,逐个检查其中的LSA。若LSA的状态更新,或本地不存在,就用LSA更新自己的数据库;同时,在某些接口上继续发送该LSA,称为“洪泛”

注意:路由器并不是直接发送接收的链路状态更新报文,而是发送根据自己的数据库生成的链路状态更新报文。

通过各路由器洪泛发送封装有自己LSA的LSU报文,各路由器的LSDB最终达到一致。

使用OSPF的各路由器基于LSDB进行最短路径优先SPF计算,构建出各种到达其他各路由器的最短路径,即构建各自的路由表。

2、链路状态算法的路由计算过程(OSPF路由计算步骤)

OSPF要求每台运行OSPF的路由器都了解整个网络的链路状态信息,这样才能计算出到达目的地的最优路径

1)OSPF的收敛过程,由链路状态公告(LSA)泛洪开始,LSA中包含了路由器已知的接口IP地址、掩码、开销和网络类型等信息。

2)收到LSA的路由器,都可以根据LSA提供的信息建立自己的链路状态数据库(LSDB),并在LSDB的基础上使用SPF算法进行运算建立起到达每个网络的最短路径树

3)最后,通过最短路径树得出到达目的网络的最优路由,并将其加入到IP路由表中

(下图)所示为OSPF的路由计算过程,大致可以分为4个步骤。

1、邻接关系建立

相邻的运行链路状态路由协议的路由器之间建立一个协议的邻居关系。只有邻接关系建立好后,然后彼此之间开始交互LSA(链路状态通告)。

与距离矢量路由协议不同,链路状态路由协议,通告的是链路状态而不是路由表

链路状态通告(LSA):每台路由器都产生一个描述自己直连接口状态(包括接口的开销、与邻居路由器之间的关系等)的通告

2、同步链路状态数据库(LSDB)

邻接关系建立好后,每个OSPF路由器会把自己的LSA通告给自己的邻居,同时接收邻居通告给自己的LSA,也会把自己知道的其他路由器的LSA通告给邻居。路由器将接收到的LSA放入自己的LSDB。路由器通过对LSDB中所存储的LSA进行解析,进而了解全网拓扑。(下左图)

链路状态数据库(LSDB):所有LSA的集合

3、SPF路由计算

LSDB同步后,每台路由器都计算出一棵以自己为根的、无环的、拥有最短路径的"树"。有了这棵"树",路由器就已经知道了到达网络各个角落的优选路径。(上右图)

最短路径算法(SPF)算的是开销--每台路由器基于LSDB,使用SPF算法进行计算。

SPF是OSPF路由协议的一个核心算法用来在一个复杂的网络中做出路由优选的决策

4、路由表生成

最后,根据SPF树,每台路由器都能计算出各自的路由信息,将计算出来的优选路径,加载进自己的路由表(Routing Table)。

链路状态路由协议总结

企业网络是由众多的路由器、交换机等网络设备之间互相连接组成的,类似一张地图。由于众多不同型号的路由器、不同类型的链路及其连接关系,造成了路由计算的复杂性。(下图)   

链路状态路由协议有四个步骤∶OSPF路由协议的工作步骤

Step 1:建立邻居关系        路由器之间发现并建立邻居关系。

Step 2:同步链路状态数据库 每台路由器产生并向邻居泛洪链路状态信息,同时收集来自其他路由器链路状态信息,完成LSDB的同步。

Step 3:计算最优路由       每台路由器基于LSDB通过SPF算法,计算得到一棵以自己为根的SPT,再以SPT为基础计算去往各邻居连接网络的最优路由,并形成路由表。

Step 4:加载路由表   根据最短路径树生成路由表项加载到路由表。


整个华为数通学习笔记系列中,本人是以网络视频与网络文章的方式自学的,并按自己理解的方式总结了学习笔记,某些笔记段落中可能有部分文字或图片与网络中有雷同,并非抄袭。完处于学习态度,觉得这段文字更通俗易懂,融入了自己的学习笔记中。如有相关文字涉及到某个人的版权利益,可以直接联系我,我会把相关文字删除。【VX:czlingyun    暗号:CSDN】

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

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

相关文章

LabVIEW汽车ECU测试系统

开发了一个基于LabVIEW开发的汽车发动机控制单元(ECU)测试系统。该系统使用了NI的硬件和LabVIEW软件,能够自动执行ECU的功能测试和性能测试,确保其在不同工作条件下的可靠性和功能性。通过自动化测试系统,大大提高了测…

使用 Rustup 管理 Rust 版本

文章目录 安装 Rustup配置镜像源安装 Rustup 安装 RustVS Code插件创建项目代码示例 Rust 官网:https://www.rust-lang.org/zh-CN/Crates 包管理:https://crates.io/Rust 程序设计语言:https://kaisery.github.io/trpl-zh-cn/通过例子学 Rust…

DevOps认证是什么?DevOps工具介绍

DevOps 这个词是由Development(开发) 和 Operations(运维)组合起来的,你可以把它理解成为一种让开发团队和运维团队紧密合作的方法。 DevOps从2009年诞生到现在已经14年多了,一开始大家还在摸索&#xff0…

因为文件共享不安全,所以你不能连接到文件共享。此共享需要过时的SMB1协议,而此协议是不安全的 解决方法

目录 1. 问题所示2. 解决方法3. 解决方法1. 问题所示 输入共享文件地址的时候,出现如下信息: 因为文件共享不安全,所以你不能连接到文件共享。此共享需要过时的SMB1协议,而此协议是不安全的,可能会是你的系统遭受攻击。你的系统需要SMB2或更高版本截图如下所示: 2. 解决…

【Elasticsearch】一、概述,安装

文章目录 概述全文搜索引擎概述ES(7.x) 安装ES(Docker)测试,是否启动成功 可视化工具配置中文 客户端Postman下载 概述 ES是开源的高扩展的分布式全文搜索引擎,实时的存储、检索数据;本身扩展性…

助力游戏实现应用内运营闭环,融云游戏社交方案升级!

通信能力在所有应用场景都是必备组件,这源于社交属性带给应用的增长神话。 在游戏场景,玩家从少数核心向大众用户泛化扩展的过程,就是游戏深度融合社交能力的过程。 从单机到联机,游戏乐趣的升级 1996 年,游戏界顶流…

理解 REST API 和 GraphQL 的区别

你可能听说过 GraphQL,但对它与 REST 的区别还不完全确定。今天我们将介绍 REST 和 GraphQL 的一些基本原理,以及它们的不同使用场景。 GraphQL 作为 REST API 的替代品越来越受欢迎,不过它不一定是完全的“替代品”。 根据你的使用情景&am…

cache映射

从主存到cache 假设把每个内存块分为4份,每次从主存中读取都是以块为单位,一次读取一个块。 (因为根据空间的局部性原理,当需要用到一个地址时,后续很大概率要用到其相邻的地址,因此一次读取一个块这种预读操作可以减…

无人机水运应用场景

航行运输 通航管理(海事通航管理处) 配员核查流程 海事员通过VHF(甚高频)系统与船长沟通核查时间。 无人机根据AIS(船舶自动识别系统)报告的船舶位置,利用打点定位 功能飞抵船舶上方。 使用…

GL823K USB 2.0 SD/MSPRO读卡器控制芯片

概述 GL823K是一个USB 2.0单轮读卡器控制芯片,可以支持SD/MMC/MSPRO闪存卡。它支持USB 2.0高速传输,它在一个芯片上可以控制读取诸如安全数字卡(SD卡),SDHC卡,迷你SD卡,微SD卡(T-Fl…

java基于ssm+jsp 二手交易平台网站

1商家能模块 商家首页,在商家首页页面可以查看个人中心、商品分类管理、商品信息管理、订单信息管理、订单配送管理信息,如图1所示。 图1商家首页界面图 个人中心,用户通过个人中心可以查看用户名、用户姓名、头像、性别、手机号码、邮箱等信…

《企业实战分享 · 常用运维中间件》

📢 大家好,我是 【战神刘玉栋】,有10多年的研发经验,致力于前后端技术栈的知识沉淀和传播。 💗 🌻 近期刚转战 CSDN,会严格把控文章质量,绝不滥竽充数,如需交流&#xff…

Linux socketcan应用编程

一、基本步骤 1、打开并绑定到 CAN 套接字 在执行任何操作之前,第一步是创建一个套接字。此函数接受三个参数 – 域/协议系列 (PF_CAN)、套接字类型(原始或数据报)和套接字协议。如果成功,该函数将返回文件…

Linux多线程【线程互斥】

文章目录 Linux线程互斥进程线程间的互斥相关背景概念互斥量mutex模拟抢票代码 互斥量的接口初始化互斥量销毁互斥量互斥量加锁和解锁改进模拟抢票代码(加锁)小结对锁封装 lockGuard.hpp 互斥量实现原理探究可重入VS线程安全概念常见的线程不安全的情况常…

实习总结 --- 内部平台使用

常用术语 CR CR–标准问题分类管理平台:由业务类型-角色-国家-品类-Page定义。 FAQSOP FAQ是端上用户自助的第一道关口,在引导用户进行自助解决上起关键作用 SOP是指标准作业程序,客服SOP是针对用户遇到的具体问题场景,给客服…

鸿蒙OS开发者高级学习第2课:自由流转(含习题答案)

自由流转两种形态:相继使用(跨端迁移);同时使用( 多端协同) 习题:

DCU整体硬件架构

DCU整体硬件架构 DCU整体硬件架构 首先,DCU通过PCI-E总线与CPU处理器相连,它是CPU主机系统的一个硬件扩展,其存在的目的是为了对程序某些模块或者函数进行加速。虽然DCU是原硬件系统的一个扩展,接受CPU调度指挥,但是在…

轻松配置,无需重复操作:PyCharm新建项目后,如何让当前新建项目使用既有虚拟环境

1、点击右上角的设置按钮 2、点击Settings 3、点击profect 4、点击python Interprter,这个是python解释器 5、点击 add interpreter,这个是增加python解释器 6、再点击add Local interpreter 7、选择第一个Virtualenv Environment,然后选择Existin…

rufus-4.5 制作 Clonezilla(再生龙)启动盘报syslinux-6.04下载错误(很实用)

1、官网下载rufus 官网下载rufus-4.5,下载地址:https://rufus.ie/downloads/ 2、下载再生龙(Clonezilla) 下载最新版本: Clonezilla live 版本: 3.1.2-22:https://sourceforge.net/projects/clonezill…

Docker拉取失败,利用 Git将 Docker镜像重新打 Tag 推送到阿里云等其他公有云镜像仓库里

目录 一、开通阿里云容器镜像服务 二、Git配置 三、去DockerHub找镜像 四、编写images.txt文件 ​五、演示 六、其他注意事项 最近一段时间 Docker 镜像一直是 Pull 不下来的状态,想直连 DockerHub 是几乎不可能的。更糟糕的是,很多原本可靠的国内…