OSPF协议RIP协议+OSPF实验(eNSP)
本篇博客主要讲解单区域的ospf,多区域的仅作了解。
目录
一、OSPF路由协议概述
1.内部网关协议和外部网关协议
二、OSPF的应用环境
1.从以下几方面考虑OSPF的使用
2.OSPF的特点
三、OSPF重要基本概念
3.1,辨析邻居和邻接关系以及七种邻居状态
3.2,DR和BDR的选举
3.3,OSPF报文格式
三,OSPF工作流程
3.1,OSPF协议的工作过程
四,OSPF实验
4.1,实验要求:
4.2,第一部分
4.3,第二部分
补充:为什么主从关系只在DR和BDR中有效?
编辑
最后
一、OSPF路由协议概述
1.内部网关协议和外部网关协议
- 自治系统(AS)
- 内部网关协议(IGP) :rip(老掉牙,现在基本不用)、ospf、is-is等
- 外部网关协议(EGP):bgp等
AS(自治系统): 网络系统 = 网络架构,统一的管理者 构建的网络的系统 相同的IGP协议 策略相对比较单一。
公有AS:一般如果该单位的网络规模比较大或者将来会发展成较大规模的网络,而且有多个出口,建议建立成一个自治系统,这样就需要AS号码用来标识这个自治系统,公有AS号是不可重复的。
私有AS:不需要申请的 ,是私人的。
内部网关协议:作用于一个AS之内的协议,比如接下来我们会讲到的OSPF。
外部网关协议:作用于两个AS之间的协议。如下图:
二、OSPF的应用环境
1.从以下几方面考虑OSPF的使用
- 网络规模
- 网络拓扑
- 其他特殊要求
- 路由器自身要求
2.OSPF的特点
- 可适应大规模网络
- 路由变化收敛速度快
- 无路由环
- 支持变长子网掩码VLSM
- 支持区域划分
- 支持以组播地址发送协议报
三、OSPF重要基本概念
1,OSPF区域:为了适应大型的网络,OSPF在AS内划分多个区域
每个OSPF路由器只维护所在区域的完整链路状态信息
2,区域ID:区域ID可以表示成一个十进制的数字
也可以表示成一个IP如:1.1.1.1,0.0.0.0
3,骨干区域Area 0(区域0是不可或缺的,其他的区域都可以没有):
负责区域间路由信息传播
4,非骨干区域:(仅作了解)
非晋干区域相互通信必须通过骨干区域
– 标准区域
– 末梢区域stub
– 完全末梢区域total stub
– 非纯末悄区域nssa
5,OSPF的process_ID:进程号 本设备标识OSPF进程的,进程号只在本地有意义,在路由器之间是没有意义的,比如说:R1路由器和R2路由器一个使用的是process_ID 10,一个使用的是process_ID 20,但是只要他们建立了邻接关系,他们还是会交换路由信息来完善自身的LASDB,但是在同一个设备的不同进程之间,他们的LSDB是不同的。
6,OSPF的router_ID : 路由器ID 设备的身份证 未来产生LSA信息会与Router-id关联。配置格式=IP格式-点分十进制//和本设备的IP地址没有关系。
router_ID两种生成方式=人为配置的优于自动产生的//配置协议时选择人为指定的方式。
- 选取路由器loopback接口上数值最高的IP地址
- 如果没有loopback接口,就选第一个UP的接口,该接口的地址成为Router-id。
如果同时UP,优选IP地址最大的,形成全局的RID。 - 也可以使用router-id命令指定Router ID(人为指定)
7,LSA:link-state-advertise:链路状态通告,通俗点来讲就是本地的详细路由信息。
8,DBD:简化的路由信息,因为如果发完整的路由信息的话,链路负担较大,所以DBD只是用来告诉对方我身上有什么网段,看对方是否需要。
9,LSDB:database:链路状态数据库 //存LSA的地点 //存路由的路由表。
10,其它类型的包:
链路状态请求包(LSR):在路由器收到包含新信息的DBD后发送,用于请求更详细的信息
链路状态更新包(LsU):收到LSR后发送链路状态通告(LSA),一个LSU数据包可能包含几个LSA
链路状态确认包(LSAck):确认已经收到DBD/LSU,每个LSA需要被分别确认
3.1,辨析邻居和邻接关系以及七种邻居状态
1,OSPF启动的第一个阶段是使用Hello报文建立邻居的过程,注意建立这三种状态只使用到了hello包。
其实,这张图是不对的(但是我找不到其他的图了),那么他不对在哪个地方呢?
首先,从单方面来讲,在R1收到了R2的第一个hello包之后,就会将对方R2由down置为init状态,然后R2也会将我置为init状态。、
之后,R1将R2放在邻居表里,发送第二个hello包,R2看见R1发来的hello包里面active neighbor是自己,所以就把R1置为2-way状态,同理R1对R2也是如此。
2,OSPF启动的第二个阶段是建立完全邻接关系
补充:
1,这七种状态是本路由器用来标识对方路由器的状态,而不是我自己的状态。
2,这里在建立完全邻接关系的时候涉及到了,一个主从关系的选举,但是其实主从关系其实只是为了解决双方谁先发DBD包的问题,在后面我们会知道,主从关系只在DR和BDR之间有效。
3,Init和2-way最大的区别:
init:收到了对方的hello报文,但是没有在active-router看到自己的RID
2-way:收到了对方的hello报文,但是在active-router看到自己的RID,如下就是2-way的报文,我们可以看到,他发给对方的第二hello包中将对方放在了邻居表里。
3.2,DR和BDR的选举
我们带着问题来看。
3.2.1,首先,我们为什么要选举DR和BDR,他们可以解决什么问题呢?
先,假设有以下四台路由器在同一广播域下,他们都运行了OSPF,那么他们要如何拿到对方的路由信息呢?按照经验,要想得到对方的路由信息,那么就要建立完整的邻接关系,那么以下四台路由器两两之间都要建立邻接关系,而建立邻接关系就要发送五组报文,所以以下四台路由器一共要建立6种邻接关系,发30个包。假如同一个广播域下的路由器越来越多,建立的邻接关系就越来越多,发送的建立邻接关系的报文也越多,对链路的负载也越大,按照公式:n(n-1)/2,假如有五台路由器,就要建立10种邻接关系。所以在一个广播域下,要选举出一个DR和一个BDR,同步同一广播域下的所有路由器的路由信息,也就是说,只有DR和BDR要和同一广播域下的所有路由器建立邻接关系,而DR other(就是非DR和BDR路由器)也从DR那里拿到了路由信息。这样,DR other之间只需要发hello包即可保持2-way,DR other和DR,BDR之间才需要发5种包,因此减小了链路的浪费。
3.2.2,DR和BDR是如何选举的呢?
自动选举DR和BDR:网段上Router lID最大的路由器将被选举为DR,第二大的将被选举为BDR
手动选举DR和BDR:
- 接口的优先级范围是0~255,数值越大,优先级越高,默认为1
- 如果优先级相同,则需要比较Router ID
- 如果路由器的优先级被设置为0,它将不参与DR和DBR的选举
选举时间:wait=40s 40s之内选举出一个DR/BDR ,接口运行OSPF开始 就开始进行DR/BDR角色的选举。
选举DR和BDR在2-WAY之后,exstart之前。
DR=指定路由器="大哥"
BDR=备份指定路由器="二哥" 为了保证DR的稳定,保证DR故障后网络不会出现过长的中断时间,此时会提前选举BDR。
DRother=非指定/备份指定路由器
选举特点:当网络中存在DR,但是不存在BDR时,此时会从网络中再选举出新的BDR,以此类推。DR和BDR不允许被抢占,即设备已经选举出DR和BDR的情况下,此时即便有新的设备加入,
为了保证稳定性,角色不会重新变化。
DR/BDR会与所有人建立FULL的邻接关系。
DRother之间只会建立2-WAY邻居关系。
区别及作用:
DR和BDR选举发生在2-WAY状态,作用:保证一个广播域中减少无用的泛洪的OSPF报文的流量。
主从关系选举发生在exstart状态,作用:保证数据库同步时的可靠及有序。
具体选举流程如下(先当小弟再做大哥):
3.3,OSPF报文格式
通用头部:
hello包:
三,OSPF工作流程
3.1,OSPF协议的工作过程
①每台路由器学习激活的直接相连的网络,
②每台路由器和直接相连的路由器互交,发送Hello报文, 建立邻居关系。
③每台路由器构建包含直接相连的链路状态的LSA (链路状态通告),链路状态通告(LSA)中记录
了所有相关的路由器,包括邻路由器的标识、链路类型、带宽等。
④每台路由器泛洪链路状态通告(LSA) 给所有的邻路由器,并且自己也在本地储存邻路由发过来的LSA,然后再将收到的LSA泛洪给自己的所有邻居,直到在同区域中的所有路由器收到了所有的LSA,每台路由器在本地数据库中保存所有收到的LSA副本,这个数据库被称作“链路状动数据库”(LSDB)。
⑤每台路由器基于本地的“链路状态数据库(LSDB)“执行“最短路径优先(SPF) “算法,并以本路由器为根,生成一个SPF树,基于这个SPF树计算去往每个网络的最短路径,也就得到了最终的路由表。
四,OSPF实验
整体的网络拓扑图如下:
4.1,实验要求:
1,要求如下AR2要作为我们这个区域中的DR,而AR4作为我们这个区域中的BDR
2,左边的路由器想要访问R7,发过去的包走下面,但是从R7发回的包走上面。
4.2,第一部分
我们首先给我们的192.168.1.0/24网段用上我们的ospf路由协议
AR2配置如下:
1,首先为AR2设置名字R2(个人习惯)
2,为接口设置ip地址
3,设置ospf进程为100
4,指定router-id,现实生活中一般是要指定的,但是不指定的话在我们实验中问题也不大。
5,设置路由器所属区域
6,向外通告网段
之后我们来看一下我们的LSDB,可以看到现在R2的LSDB还没有任何东西,因为我们现在只有R2在区域0中。
但是,现在这个区域的DR已经确定,也就是R2,具体原因不做解释。
我们现在在网段中随意抓个包,看看,
可以看到,R2一直在往组播地址发送Holle报文,在hello报文中我们可以看到R2已经成为DR,BDR是0.0.0.0意味着还没有BDR。
之后我们在开启R4,让他成为BDR。
对R4做如下配置:
抓包后,我们看到,R2和R4都在向组播地址224.0.0.5发送Hello报文,并且我们可以观察到BDR已经是R4。实验到现在,区域0里面已经有了DR和BDR,我们现在要开始配置其他路由器R1和R3,让他们也加入区域0中。
在这里我只展现R3的配置,R1的配置和R3的差不多!
R3配置如下:
最后,我们可以查看R3中的邻居状态表
4.3,第二部分
现在,我们的左边的实验目的已经达到,我们来开始右边的实验。
R4,R5,R6,R7的配置如下:
注意:R4和R7均有一个环回口用于测试,在上图可以看到。
然后,我们在去宣告一下R4567身上的网段。这里只展现R7的。
注意:路由器身上的环回口也需要宣告。其他的路由器如法炮制即可。注意上面的所有路由器都加了同一个域0。
之后,我们在R4身上看到了R4已经从其他的邻居那里学来了路由,连下一跳都给你了
从上面的路由表中我们可以看到,去往7.7.7.7的下一跳有两条,那么我们如何来控制只走下面的这一条呢?我们就需要修改接口的cost值。
那么我们需要了解cost值是如何计算的cost=100/接口带宽,由于我们这里用的是G口,带宽是1000,所以cost是1(不满1当作1)。而且计算一条链路的cost值,需要看这个目标路由器对于源路由去的收敛方向。R7对于R4来说其中一链路的收敛方向如下,那么接口也是按R5-g0/0/1和R4-g0/0/1接口计算。那么这里我们就可以修改R5-g0/0/1接口的cost值来抹除这条R4到R7的路径。
还有为什么要修改cost值呢?这就和路由的加表原则有关了,加表原则如下:
操作如下:
R5:
然后我们再在R4上查看去往R7的路由,我们发现只有我们想要的那一条了。
然后我们来修改R6,因为,对于R7到R4的路由也有两条,并且我们只想要上面的路由,所以我们修改R6-g0/0/0,步骤同上,我就不演示了。
最后我们来验证一下,使用R4测试,我们可以看到,包确实是从下面去的。如下图:
在使用R1,看可不可以ping 7.7.7.7,可以看到,ping通了,所以试验成功。
补充:为什么主从关系只在DR和BDR中有效?
我们看192.168.1.0/24网段。 由上面的实验可知,AR2是DR,AR4是BDR.
查看AR2,可以看到是是AR4的主人。
反看AR4 ,可以看到,AR4是AR2的从属。
我们再看看DR other R1的,我们可以看到,无论是对谁,他的状态都是Master。
所以, 主从关系只在DR和BDR中有效。
最后
本篇博客对OSPF的介绍和实验就到这里了,如果本篇博客对你有帮助的话请点赞收藏支持一下,谢谢!答应我!不要白嫖号吗?哈哈哈!咱们下篇博客见。
相关文章:

OSPF协议RIP协议+OSPF实验(eNSP)
本篇博客主要讲解单区域的ospf,多区域的仅作了解。 目录 一、OSPF路由协议概述 1.内部网关协议和外部网关协议 二、OSPF的应用环境 1.从以下几方面考虑OSPF的使用 2.OSPF的特点 三、OSPF重要基本概念 3.1,辨析邻居和邻接关系以及七种邻居状态 3…...

leetcode每日一练-第108题-将有序数组转换为二叉搜索树
一、思路 递归 二、解题方法 在给定中序遍历序列数组的情况下,每一个子树中的数字在数组中一定是连续的,因此可以通过数组下标范围确定子树包含的数字,下标范围记为 [left,right]。对于整个中序遍历序列,下标范围从 left0到 ri…...

王道《操作系统》学习(二)—— 进程管理(二)
2.1 处理机调度的概念、层次 2.1.1 调度的基本概念 2.1.2 调度的三个层次 (1)高级调度(作业调度) (2)中级调度(内存调度) 补充知识:进程的挂起状态和七状态模型 &#x…...

Vulnhub: shenron: 3靶机
kali:192.168.111.111 靶机:192.168.111.171 信息收集 端口扫描 nmap -A -sC -v -sV -T5 -p- --scripthttp-enum 192.168.111.171 修改hosts后访问目标80端口,发现是wordpress wpscan收集目标用户,爆破出密码:ilov…...

Kubernetes高可用集群二进制部署(二)ETCD集群部署
Kubernetes概述 使用kubeadm快速部署一个k8s集群 Kubernetes高可用集群二进制部署(一)主机准备和负载均衡器安装 Kubernetes高可用集群二进制部署(二)ETCD集群部署 Kubernetes高可用集群二进制部署(三)部署…...
mysql主从复制及原理
目录 主从复制原理实现主从复制 主从复制原理 主要基于MySQL二进制日志 主要包括三个线程(2个I/O线程,1个SQL线程) 1、MySQL将数据变化记录到二进制日志中; 2、Slave将MySQL的二进制日志拷贝到Slave的中继日志中; …...

MQTT服务器详细介绍:连接物联网的通信枢纽
随着物联网技术的不断发展,MQTT(Message Queuing Telemetry Transport)协议作为一种轻量级、可靠、灵活的通信协议,被广泛应用于物联网领域。在MQTT系统中,MQTT服务器扮演着重要的角色,作为连接物联网设备和…...
通过VBA宏合并Excel工作表
工作中经常会用到的把几个Excel文件合并到一个,或者是把一个Excel文件里的所有Sheet合并到一个Sheet来进行统计。下面分别提供用vba宏来解决这两个问题的方法。 1、合并Excel文件 打开一个空Excel文件,AltF11,插入一个模块,开始…...

Mac 定时重启 TouchBar 脚本(缓解闪烁问题)
背景 Mac 笔记本 TouchBar 是真的脆啊,合盖使用一段时间就废了,右侧一直闪烁简直亮瞎眼 😂 经过观察,总结出闪烁规律如下: 工作状态:不断操作电脑时,触控栏处于工作状态,几乎不闪…...

Redis主从复制、哨兵机制、集群分片
目录 一.主从复制 1.概述 2.主从架构相比于单点架构的优势 3.主从复制原理和工作流程 第一次同步 第一阶段:建立链接、协商同步 第二阶段:主服务器同步数据给从服务器 第三阶段:主服务器发送新写操作命令给从服务器 基于长连接的命…...

字段填充策略 FieldFill
实体类中有如下属性,通过上面的自动填充属性,我们可以实现在进行插入(insert)操作时对添加了注解TableField(fill FieldFill.INSERT)的字段进行自动填充(解释:后面会写配置自动填充的配置类,该…...
Docker run 启动容器报错
今天在Windows下启动docker容器发现的三个错误: Ports are not available: exposing port TCP 0.0.0.0:1521 -> 0.0.0.0:0: listen tcp 0.0.0.0:1521: bind: Only one usage of each socket address (protocol/network address/port) is normally permitted. 端口…...

Golang之路---03 面向对象——类型断言
类型断言 作用 检查 i 是否为 nil检查 i 存储的值是否为某个类型 使用方式 第一种: t : i.(T)这个表达式可以断言一个接口对象(i)里不是 nil,并且接口对象(i)存储的值的类型是 T,如果断言成…...

Atcoder 做题记录
My OI Blog A R C 155 F \mathbb{ARC \ 155 \ F} ARC 155 F E, F 先咕着,做一些多项式题,这篇题解是我人工翻译的 [1] Double Counting 双重计数 考虑从叶子节点开始,用唯一的方式(如果有的话)来构造出一棵满足条件的树…...

C++之观察者模式(发布-订阅)
目录 模式简介 介绍 优点 缺点 代码实现 场景说明 实现代码 运行结果 模式简介 观察者模式(Observer Pattern),也叫我们熟知的发布-订阅模式。 它是一种行为型模式。 介绍 观察者模式主要关注的是对象的一对多的关系, …...

无头单链表,有完整测试程序
🍟无头单链表 👻无头单链表的所有结点都存储有效信息 👻无头单链表相对带头单链表,在有些涉及更改头节点的函数上需要传二级指针 🍟头文件list.h #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #includ…...

2023年第四届“华数杯”数学建模思路 - 案例:FPTree-频繁模式树算法
## 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 算法介绍 FP-Tree算法全称是FrequentPattern Tree算法,就是频繁模式树算法,他与Apriori算法一样也是用来挖掘频繁项集的,…...

MySQL做分布式锁
分布式锁mysql实现方式 方式1:唯一索引 创建锁表,内部存在字段表示资源名及资源描述,同一资源名使用数据库唯一性限制。多个进程同时往数据库锁表中写入对某个资源的占有记录,当某个进程成功写入时则表示其获取锁成功其他进程由于…...
Python学习笔记:变量类型、字符串基本操作
1.注释 单行注释 # 单行注释 多行注释 """ 多行注释 """2.变量类型 # 基本变量类型 a 1 # integer b 1.5 # float c string # String d "string" # string e False # boolean # list\tuple\dictionar…...

JVM的组件、自动垃圾回收的工作原理、分代垃圾回收过程、可用的垃圾回收器类型
详细画的jvm模型图 https://www.processon.com/diagraming/64c8aa11c07d99075d934311 官方网址 https://www.oracle.com/webfolder/technetwork/tutorials/obe/java/gc01/index.html 相关概念 年轻代是所有新对象被分配和老化的地方。当年轻代填满时,这会导致m…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?
编辑:陈萍萍的公主一点人工一点智能 未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战,在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...

srs linux
下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935,SRS管理页面端口是8080,可…...

SpringBoot+uniapp 的 Champion 俱乐部微信小程序设计与实现,论文初版实现
摘要 本论文旨在设计并实现基于 SpringBoot 和 uniapp 的 Champion 俱乐部微信小程序,以满足俱乐部线上活动推广、会员管理、社交互动等需求。通过 SpringBoot 搭建后端服务,提供稳定高效的数据处理与业务逻辑支持;利用 uniapp 实现跨平台前…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

Android15默认授权浮窗权限
我们经常有那种需求,客户需要定制的apk集成在ROM中,并且默认授予其【显示在其他应用的上层】权限,也就是我们常说的浮窗权限,那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

莫兰迪高级灰总结计划简约商务通用PPT模版
莫兰迪高级灰总结计划简约商务通用PPT模版,莫兰迪调色板清新简约工作汇报PPT模版,莫兰迪时尚风极简设计PPT模版,大学生毕业论文答辩PPT模版,莫兰迪配色总结计划简约商务通用PPT模版,莫兰迪商务汇报PPT模版,…...

WPF八大法则:告别模态窗口卡顿
⚙️ 核心问题:阻塞式模态窗口的缺陷 原始代码中ShowDialog()会阻塞UI线程,导致后续逻辑无法执行: var result modalWindow.ShowDialog(); // 线程阻塞 ProcessResult(result); // 必须等待窗口关闭根本问题:…...

Linux 下 DMA 内存映射浅析
序 系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存,但最终会调到 DMA 子系统的dma_alloc_coherent()/dma_alloc_attrs() 等接口。 关于 dma_alloc_coherent 接口详细的代码讲解、调用流程,可以参考这篇文章,我觉得写的非常…...