OSPF---开放式最短路径优先协议

1. OSPF描述

          OSPF协议是一种链路状态协议。每个路由器负责发现、维护与邻居的关系,并将已知的邻居列表和链路费用LSU报文描述,通过可靠的泛洪与自治系统AS内的其他路由器周期性交互,学习到整个自治系统的网络拓扑结构;并通过自治系统边界的路由器注入其他AS的路由信息,从而得到整个Internet的路由信息。每隔一个特定时间或当链路状态发生变化时,重新生成LSA,路由器通过泛洪机制将新LSA通告出去,以便实现路由的实时更新

          这样,每台路由器都收到了自制系统中所有路由器生成的LSA,这些LSA的集合组成了LSDB(链路状态数据库),这样所有的OSPF路由器都维护一个相同的描述自治系统内部结构的数据库。

1.1基本概念

  • 协议使用范围----IGP
  • 链路状态型协议----传递拓扑
  • 传递真实掩码信息----无类别路由协议
  • OSPF版本
    • OSPFv1
    • OSPFv2----IPv4
    • OSPFv3----IPv6
  • 使用SPF算法
  • OSPF传递的是LSA信息(链路状态通告)
  • OSPF更新方式
    • 触发更新
    • 周期链路状态刷新-----30min
  • OSPF更新地址---组播
    • 224.0.0.5/224.0.0.6
  • OSPF开销值===参考带宽/实际带宽(参考带宽默认为100Mbps)
  • OSPF进行跨层封装----基于IP协议进行封装,协议号89

1.2 优点

  • 支持在多条等代价路由之间的负载均衡;
  • 支持路由信息交换的认证;
  • 可用作大型自治系统的内部路由协议。
  • OSPF采用SPF算法计算路由,从算法上保证了不会产生路由环路
  • OSPF不限制网络规模,更新效率高,收敛速度快

2.OSPF数据包

  •  hello报文
    • 用来周期性发现、建立、保活OSPF邻居关系。
    • hello time:10S发送一次hello报文,来确认邻居的存在
    • 如果一个dead time时间没有收到邻居发送给自己的hello报文,则认为邻居不存在
    • time一般为hello时间的四倍,默认情况下为40S。
    • Router-ID------RID
      • 全域唯一,标识路由器的身份
      • 使用IP地址的表示形式
        • 配置方式:
          • 1、手工配置:满足上面两条规则即可。
            2、自动配置:路由器默认优选最大环回IP地址,没有环回则选择最大物理IP地址。
            注意:
                   启动OSPF进程前,必须有接口IP地址。若有,则在第一次启动OSPF进程时,选择第一个配置的IP地址作为RID值。
          • 在思科中,若没有IP,则OSPF启动失败。在华为中,RID会设定为0.0.0.0。
          • 华为逻辑:在第一次启动设备时,选择第一个UP的接口的IP作为全局RID。之后按照国际标准执行。
  • DBD报文
    • 数据库描述报文
    • 携带路径信息的摘要信息----为了避免重复更新和减少更新量。
  • LSR报文
    • 链路状态请求报文
    • 根据DBD中的信息,请求获取未知的链路信息(LSA信息)
  • LSU报文
    • 链路状态更新报文
    • 携带有真正的LSA信息的数据包
  • LSAck报文
    • 链路状态确认报文

3.OSPF七种邻居状态机

  • OSPF七种状态机
  • down----关闭状态-----一旦启动了OSPF协议,则发出hello报文,进入下一状态
  • init-----初始化状态----当收到的hello报文中,存在本地RID值时,进入下一状态
  • 2-way-----双向通讯状态-----------邻居关系建立的标志。
    • 条件匹配:匹配成功则进入下一阶段,失败则停留在邻居关系。
  • exstart----预启动状态-----使用未携带信息的DBD报文进行主从关系选举,RID大的为主
  • exchange-----准交换----使用携带目录信息的DBD包进行目录共享
  • loading-----加载状态-----邻居间使用LSR/LSU/LSACK三种报文来获取完整的拓扑信息
  • full----转发状态----拓扑信息交换完成后进入该状态-----邻接关系建立的标志。

 3.1条件匹配

  • 设备接口角色
    • 指定路由器------DR
    • 备份指定路由器-----BDR
    • 其他路由器----DRother
  • 角色之间的关系
    • DR与BDR----邻接
    • DR与DRother---邻接
    • BDR与DRother---邻接
    • DRother与DRother----邻居
  • OSPF条件匹配的情况
    • 在以太网网络中-----必须进行条件匹配
    • 在点到点网络中-----不需要进行条件匹配
  • 选举规则
    • 1. 优先级,默认为1,0-255,越大越优
    • 2. RID,越大越优
  • 选举范围
    • 一个广播域,进行一次条件匹配。
    • 条件匹配是属于非抢占模式-----一旦选举成功,不会因为新加入的设备而重新选举。

 4.OSPF七种接口状态机

  • Down:接口的初始状态。表明此时接口不可用,不能用于收发流量。
  • Loopback:设备到网络的接口处于环回状态。环回接口不能用于正常的数据传输,但可以通过Router-LSA进行通告。因此,进行连通性测试时能够发现到达这个接口的路径。
  • Waiting:设备正在判定网络上的DR和BDR。在设备参与DR和BDR选举前,接口上会启动Waiting定时器。在这个定时器超时前,设备发送的Hello报文不包含DR和BDR信息,设备不能被选举为DR或BDR。这样可以避免不必要地改变链路中已存在的DR和BDR。仅NBMA网络、广播网络有此状态。
  • P-2-P:接口连接到物理点对点网络或者是虚拟链路,这个时候设备会与链路连接的另一端设备建立邻接关系。仅P2P、P2MP网络有此状态。
  • DROther:设备没有被选为DR或BDR,但连接到广播网络或NBMA网络上的其他设备被选举为DR。它会与DR和BDR建立邻接关系。
  • BDR:设备是相连的网络中的BDR,并将在当前的DR失效时成为DR。该设备与接入该网络的所有其他设备建立邻接关系。
  • DR:设备是相连的网络中的DR。该设备与接入该网络的所有其他设备建立邻接关系。

 5.OSPF工作过程

  • OSPF协议启动后,路由器A向本地所有启动了OSPF协议的直连接口,使用组播地址224.0.0.5发送——hello报文
    • 该hello报文中携带了本地的全域唯一的RID值
  • 当对端路由器B接收到该报文后,也会回复hello报文
    • 该hello报文中携带了A的RID值。
  • 此时,A与B建立邻居关系,并生成邻居表。
  • 邻居关系建立后,邻居之间进行条件匹配,匹配失败则停留在邻居关系,仅使用hello报文保活。
    • 若匹配成功,则可以开始建立邻接关系
  • 邻接间共享DBD报文,将本地与邻接之间的DBD报文进行对比,查找本地没有的LSA信息,之后使用LSR来询问,对端使用LSU回复具体的LSA信息,之后本地使用LSAck报文进行确认。
    • 该过程全部完成后,生成数据库表(LSDB)
  • 在之后,本地基于数据库表,启用SPF算法,计算到达所有未知网段的最短路径,然后将其加载到本地的OSPF路由表中。
    • 并将OSPF路由表中的部分路由加载到本地全局路由表中。
    • 此时,路由器完成路由收敛工作。
  • 最后,使用hello报文进行周期保活,并且每30min进行一次链路状态刷新。

6.OSPF基本配置

1.启动OSPF协议,配置进程号(仅具有本地意义),手工配置RID值

  • 若没有配置RID值,则设备自动生成(环回接口最大IP>物理接口最大IP)
  • [r1]ospf 1 router-id 1.1.1.1

2.配置区域

  • [r1-ospf-1]area 0

3. 宣告:激活接口,发布拓扑或路由

  • 宣告网段
    • [r1-ospf-1-area-0.0.0.0]network 1.1.1.0 0.0.0.255
    • 反掩码:32位二进制,使用点分十进制表示,由连续0+连续1
  • 接口宣告方式-----精准宣告
    • [r1-ospf-1-area-0.0.0.0]network 12.0.0.1 0.0.0.0
  • OSPF邻居表
    • [r2]display ospf peer ---查看OSPF邻居
    • [r2]display ospf peer brief ----查看OSPF邻居简表
  • OSPF数据库表
    • [r2]display ospf lsdb -----查看OSPF数据库表
  • OSPF路由表
    • [r2]display ospf routing ---查看OSPF路由表
    • OSPF优先级====10
  • reset ospf 1 process -----重置OSPF进程

6.1 OSPF扩展配置

  • 修改OSPF默认参考带宽
    • [r2-ospf-1]bandwidth-reference 10000 -----修改参考带宽,两端均需要修改
  • 修改接口优先级,从而干涉条件匹配
    • [r1-GigabitEthernet0/0/0]ospf dr-priority 10 -----在接口修改
    • [r1-GigabitEthernet0/0/0]ospf dr-priority 0 ---优先级修改为0,代表放弃选举
  • 手工汇总
    • [r2-ospf-1-area-0.0.0.0]abr-summary 192.168.0.0 255.255.252.0
    • 必须在ABR上配置
    • 汇总的明细路由来源在那个区域,进入那个区域进行配置
  • 缺省路由
    • 在边界设备上
    • [r1-ospf-1]default-route-advertise -----非强制性下发,要求边界路由器中存在缺省路由才
    • 可以下发
    • [r1-ospf-1]default-route-advertise always -----强制性下发,不要求本地存在缺省路由
  • 静默接口
    • 不接受也不发送hello报文,与RIP的静默接口不同。
    • [r3-ospf-1]silent-interface GigabitEthernet 0/0/1
  • 接口认证
    • [r1-GigabitEthernet0/0/0]ospf authentication-mode ?
      • md5 Use MD5 algorithm -----MD5认证
      • null Use null authentication -----不认证----OSPF默认情况
      • simple Simple authentication mode ------简单认证----明文认证
    • [r1-GigabitEthernet0/0/0]ospf authentication-mode md5 1 cipher 123456
    • [r2-GigabitEthernet0/0/0]ospf authentication-mode md5 1 cipher 123456
  • 加快收敛
    • [r3-GigabitEthernet0/0/0]ospf timer hello ? -------一端修改,另一端必须修改,若不修改,则会导致邻居关系无法建立。

                  INTEGER<1-65535> Second(s)

7.OSPF区域化结构 

  • OSPF为了适应大中型网络环境,进行了结构化部署------区域划分
  • 区域划分的特点
    • 区域内部传递拓扑信息,区域间传递路由信息。
    • 区域划分是基于路由器接口的。
    • 区域编号----32bit
      • 区域0-----骨干区域
      • 非骨干区域----非0区域

    • 区域划分规则
      • 所有的非骨干区域都必须和骨干区域直接相连----星型拓扑
      • 骨干区域唯一
  • 区域边界路由器----ABR
    • 同时属于多个区域,且至少有一个接口属于骨干区域。
    • 在骨干区域中至少存在一个活跃的邻居。
区域划分目的:为了减少OSPF域中LSA的数量

如果一台路由器的多个接口分别接入到了多个不同的区域,则该设备会为每一个区域单独维护一套LSDB

要求:

1、OSPF要求域中的所有非骨干区域(区域ID不为0)都必须与Area0相连

2、骨干区域不能被分割

OSPF区域结构部署规则的必要性

ABR设备规则:

  1. 至少连接两个区域
  2. 连接的区域中至少有一个是区域0
  3. 在区域0中至少存在一个活跃的邻居

ABR功能:传递区域间路由信息

OSPF为了保证所有工程师遵循两条区域划分规则,作出如下规定:

  • 非骨干区域之间不允许直接相互发布区域间路由信息。---因为不存在ABR设备。

  • 从非骨干区域收到的路由信息,ABR能接收但不会使用这条路由信息-----OSPF的区域水平分割机制(从一个区域学习到的路由信息,不能再传递回该区域)

OSPF有如下规定:

  1. 对于伪ABR设备,不允许转发区域间路由信息。
  2. 对于真是ABR设备:
  • 可以将直连的非骨干区域的区域内路由信息传递给骨干区域
  • 可以将直连的骨干区域的区域内路由信息传递给非骨干区域
  • 能够将自己从骨干区域学习到的域间路由信息传递给非骨干区域

路由器角色

  • 内部路由器---IR---所有接口都接入同一个OSPF区域
  • 骨干路由器---BR---接入Area0的路由器
  • 区域边界路由器---ABR
  • AS边界路由器---ASBR
    • 工作在OSPF自治系统的边界,负责将OSPF域外的路由引入到本OSPF域中。
      1. 设备连接在不同的AS,且具有活跃的邻居。
      2. 该设备执行了重发布操作。

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

URL编码:原理、应用与安全性

title: URL编码&#xff1a;原理、应用与安全性 date: 2024/3/29 18:32:42 updated: 2024/3/29 18:32:42 tags: URL编码百分号编码特殊字符处理网络安全应用场景标准演变未来发展 在网络世界中&#xff0c;URL&#xff08;统一资源定位符&#xff09;是我们访问网页、发送请求…

day69实现MyBatis 的Mapper接口 封装SqlSession对象 mapper接口形参怎么给占位符赋值

一 创建项目的准备工作 1 添加jar包 MySql.jar .MyBatis.jar 2 在src中配置MyBatis.xml文件 二 封装SqlSession对象 1 SqlSessionFactoryBuilder 生命周期 这个类可以被实例化,使用和丢弃。一旦你创建了 SqlSessionFactory 后…

九河云荣获“华为2024·亚太区年度杰出合作伙伴奖”

2024年3月26日~27日&#xff0c;以“加速智能化&#xff0c;一切皆服务”为主题的华为亚太生态伙伴大会在东莞隆重开幕&#xff0c;九河云作为专业的多云管理服务商&#xff0c;凭借多年来在云领域的赋能发展应邀出席并荣获“亚太区年度杰出伙伴奖”&#xff0c;这不仅彰显了九…

为什么要学Python?Python的优势在哪?

人生苦短&#xff0c;我用 Python 不知道从什么时候开始流行这句话 Python 是个什么神仙编程语言 为啥全世界都在鼓励孩子学 Python 简单容易上手 国内、国际的竞赛机会多&#xff0c;含金量足 Python 好就业、薪资高 下面且看详细分析 01 什么是Python / 科技编程老师…

MYSQL8.0安装、配置、启动、登入与卸载详细步骤总结

文章目录 一.下载安装包1.方式一.官网下载方式二.网盘下载 二.解压安装三.配置1.添加环境变量 三.验证安装与配置成功四.初始化MYSQL五.注册MySQL服务六.启动与停止MYSQL服务七.修改账户默认密码八.登入MySQL九.卸载MySQL补充&#xff1a;彻底粉碎删除Mysql 一.下载安装包 1.方…

A Little Is Enough: Circumventing Defenses For Distributed Learning

联邦学习的攻击方法&#xff1a;LIE 简单的总结&#xff0c;只是为了能快速想起来这个方法。 无目标攻击 例如总共50个客户端&#xff0c;有24个恶意客户端&#xff0c;那么这个时候&#xff0c;他需要拉拢2个良性客户端 计算 50 − 24 − 2 50 − 24 0.923 \frac{50-24-2}{…

rust使用Command库调用cmd命令或者shell命令,并支持多个参数和指定文件夹目录

想要在不同的平台上运行flutter doctor命令&#xff0c;就需要知道对应的平台是windows还是linux&#xff0c;如果是windows就需要调用cmd命令&#xff0c;如果是linux平台&#xff0c;就需要调用sh命令&#xff0c;所以可以通过cfg!实现不同平台的判断&#xff0c;然后调用不同…

【python】深入探讨flask是如何预防CSRF攻击的

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

【C++杂货铺】内管管理

目录 &#x1f308;前言&#x1f308; &#x1f4c1; C/C中内存分布 &#x1f4c1; new 和 delete的使用 &#x1f4c1; new 和 delete的优点 &#x1f4c1; new 和 delete的原理 &#x1f4c2; operator new 和 operator delete函数 &#x1f4c2; 内置类型 &#x1f4c2…

对iOS的内存存储的一些理解

最近写项目的时候遇到了一些内存上的问题&#xff08;比如内存泄漏等等&#xff09;&#xff0c;通过网上的方法解决后&#xff0c;好奇iOS的数据是如何存储的&#xff0c;特记于此。 一、iOS的内存区域 iOS 中应用程序使用的计算机内存不是统一分配空间&#xff0c;运行代码使…

Javascript — 异步方法与异常捕获问题

问题&#xff1a;try catch为什么不能捕获未被 await 修饰的异步方法异常 async function throwError() {throw new Error("自定义Error&#xff01;") }let testOne async () > {console.debug("start testOne")try {throwError()} catch (e) {conso…

【问题分析】InputDispatcher无焦点窗口ANR问题【Android 14】

1 问题描述 Monkey跑出的无焦点窗口的ANR问题。 特点&#xff1a; 1&#xff09;、上层WMS有焦点窗口&#xff0c;为Launcher。 2&#xff09;、native层InputDispacher无焦点窗口&#xff0c;上层为”recents_animation_input_consumer“请求了焦点&#xff0c;但是”rece…

大话设计模式之简单工厂模式

简单工厂模式&#xff08;Simple Factory Pattern&#xff09;是一种创建型设计模式&#xff0c;属于工厂模式的一种。在简单工厂模式中&#xff0c;有一个工厂类负责根据输入参数的不同来创建不同类的实例。 简单工厂模式包含以下几个要素&#xff1a; 1. **工厂类&#xff0…

太阳能发电园区3D可视化:揭秘绿色能源新纪元

在科技飞速发展的今天&#xff0c;绿色能源已成为推动社会进步的重要力量。太阳能发电作为绿色能源的重要代表&#xff0c;正在全球范围内掀起一股清洁能源的革命浪潮。 太阳能发电园区作为集中展示太阳能发电技术和应用的场所&#xff0c;其规模之大、设备之复杂&#xff0c;常…

ClickHouse03-小白如何快速搭建ClickHouse集群

普通测试通常使用ClickHouse单节点就可以了&#xff0c;但是生产环境不免需要考虑多活、负载等高可用问题&#xff0c;集群就成了基础需求 ClickHouse在集群的选择上&#xff0c;作者已知的有两种&#xff1a; 使用ZooKeeper作为节点协调的组件&#xff0c;使用ClickHouse-Kee…

算法---动态规划练习-7(按摩师)【类似打家劫舍】

按摩师 1. 题目解析2. 讲解算法原理3. 编写代码 1. 题目解析 题目地址&#xff1a;点这里 2. 讲解算法原理 首先&#xff0c;给定一个整数数组 nums&#xff0c;其中 nums[i] 表示第 i 天的预约时间长度。 定义两个辅助数组 f 和 g&#xff0c;长度都为 n&#xff08;n 是数组…

201基于matlab的成绩管理系统

基于matlab的成绩管理系统。自带的GUI界面设计了一个成绩管理界面&#xff0c;可进行成绩的载入、查询、绘图、求平均分。可更改自己的数据进行录入。包含作业文档。程序已调通&#xff0c;可直接运行。 201 matlab 成绩管理系统 GUI - 小红书 (xiaohongshu.com)

C语言函数的定义、声明、调用与返回

在C语言中&#xff0c;函数是一种模块化和结构化的编程方式&#xff0c;用于封装特定的功能和逻辑。通过函数&#xff0c;可以将程序分解成多个小的模块&#xff0c;使得程序结构更清晰、易于理解和维护。本文将深入介绍C语言中函数的定义、声明、调用与返回&#xff0c;以帮助…

git的使用日常习惯规范与一些特殊操作

git的使用日常习惯规范与一些特殊操作 操作习惯规范创建本地新分支&#xff0c;推送新分支到云端仓库1.创建一个本地的login分支2.创建新分支后切换到新分支3.推送新分支到云端 git的特殊操作撤回commit&#xff08;取消提交到本地版本库的动作&#xff0c;本地工作区写的代码不…

基于单片机锂电池电量检测数码管显示系统设计

**单片机设计介绍&#xff0c;基于单片机锂电池电量检测数码管显示系统设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机锂电池电量检测数码管显示系统设计的主要目标是实时、准确地检测锂电池的电量&#xff0c;并…