1、实验目的

  • 理解 OSPF 邻居关系和 OSPF 邻接关系的含义及差别
  • 观察 OSPF 邻居邻接关系的建立过程
  • 观察 OSPF 链路状态数据库的同步过程

2、实验原理

OSPF 网络中,路由器在发送任何链路状态信息之前,必须先建立起正确的 OSPF 邻居、 邻接关系。

OSPF 路由器使用 Hello 报文来建立邻居关系,具体地,OSPF 路由器会检查所收到的 Hello 报文中的各种参数,如 Router-ID、Area-ID、认证信息、网络掩码、Hello 时间间隔等。 如果这些参数和接收接口上配置的对应参数都——保持一致,则邻居关系就会建立起来,否则就无法建立起邻居关系。

OSPF 路由器的邻居关系建立完成之后,下一步是建立邻接关系。并不是所有的 OSPF 邻居之间都可以建立邻接关系,这要取决于 OSPF 邻居之间的网络类型。例如,在点到点网络上,有效的 OSPF 邻居关系都可以进一步形成邻接关系。而在广播型网络上,会选举 DR 和 BDR,DR 和 BDR 会与所有其他路由器都建立邻接关系,其他路由器都只与 DR 和 BDR 建立邻接关系。

3、实验平台

eNSP 、Wireshark

4、实验内容

4.1 在指定拓扑上完成相应路由器的基本配置

本实验模拟了一个跨国企业网络场景, 国内集团总部的路由器 R1、R2、R3 组成了一个广播型网络,国外分公司 1 的路由器 R4 与国内集团总部核心路由器 R1 组成了一个点到点网络,国外分公司 2 的路由器 R5 与 国内集团总部核心路由器 R1 组成了另一个点到点网络。

按照上述要求搭建如下网络拓扑:

编址如下:

R1:
sys
sysname R1
int loop 0
ip add 10.0.1.1 32
int s0/0/1
ip add 10.0.14.1 24
int s0/0/0
ip add 10.0.15.1 24
int g0/0/0
ip add 10.0.123.1 24
q R2:
sys
sysname R2
int loop 0
ip add 10.0.2.2 32
int g0/0/0
ip add 10.0.123.2 24
q R3:
sys
sysname R3
int loop 0
ip add 10.0.3.3 32
int g0/0/0
ip add 10.0.123.3 24
q R4:
sys
sysname R4
int loop 0
ip add 10.0.4.4 32
int s0/0/1
ip add 10.0.14.4 24
q R5:
sys
sysname R5
int loop 0
ip add 10.0.5.5 32
int s0/0/0
ip add 10.0.15.5 24
q

4.2 配置OSPF路由协议

在每台路由器上进行OSPF协议的配置,其中R1、R2、R3之间的链路属于区域0,R1和R4之间的链路属于区域1,R1和R5之间的链路属于区域2。

[R1] ospf router-id 10.0.1.1 

[R1-ospf-1]area 0 

[R1-ospf-1-area-0.0.0.0]network 10.0.123.0 0.0.0.255 

[R1-ospf-1-area-0.0.0.0]network 10.0.1.1 0.0.0.0 

[R1-ospf-1-area-0.0.0.0]area 1 

[R1-ospf-1-area-0.0.0.1]network 10.0.14.0 0.0.0.255

[R1-ospf-1-area-0.0.0.1]area 2 

[R1-ospf-1-area-0.0.0.2]network 10.0.15.0 0.0.0.255

[R2]ospf router-id 10.0.2.2 [R2-ospf-1]area 0 

[R2-ospf-1-area-0.0.0.0]network 10.0.123.0 0.0.0.255 

[R2-ospf-1-area-0.0.0.0]network 10.0.2.2 0.0.0.0 

[R3]- [R5] 类似[R2]

配置完成后,

  • 在R1上查看OSPF邻居建立情况

  • 邻居状态详细信息

可以看出,R1,R2,R3的广播网络完成了DR和BDR的选举,R3为DR,R2为BDR;R1和R4,R1和R5没有选举DR和BDR是因为他们是点到点网络

  • DR基于接口进行选举
  • DR可以减少链路中的邻接关系,BDR是DR的备份,链路中的所有路由器只和DR&BDR建立邻接关系
  • DR是基于端口的DR优先级进行选举(0-255)
  • 优先级值越高越优先,当优先级值相同时比较Router ID,Router ID越大越优先
  • 非抢占式选举

在 R1 上查看广播型网络的接口 GE 0/0/0 和点到点网络的接口 Serial 0/0/1 的详细情况,得到广播网络接口和点到点网络接口默认的 hello 时间间隔,失效时间大小。

display ospf interface GigabiEthernet0/0/0

display ospf interface Serial0/0/1

4.3 观察OSPF邻居邻接关系的建立过程

观察在广播网络上 OSPF 邻居邻接关系的建立过程。为了在 R1 上清晰地观察到广 播网络上 OSPF 邻居邻接关系的建立过程,先关闭 R1 上 Serial 0/0/1 和 Serial 0/0/0 接 口。

[R1]interface Serial 0/0/1
[R1-Serial0/0/1]shutdown
[R1-Serial0/0/1]interface Serial 0/0/0
[R1-Serial0/0/0]shutdown
  • 在 R1 上查看 OSPF 邻居状态
display ospf peer brief

由上图可见关闭了和R1相连的 R4、R5的Serial0/0/1和Serial0/0/0接口后,R1与他们的邻接状态消失,只与R2和R3保持邻接状态。

在R1上重启OSPF进程,通过Debugging调试观察R1与R2之间的OSPF邻接关系的建立过程。

<R1>debugging ospf packet
<R1>reset ospf process

![image-20211029194412142](C:\Users\Chenxu Gong\AppData\Roaming\Typora\typora-user-images\image-20211029194412142.png)

R1 和 R2 的邻居关系由 full 状态转到 down 状态,尽管 hello 报文通信后,又变为 init 状态,继而通过 2-way、exchange、loading 等状态,再次进入到 full 状态。

我们可以通过下图清晰地观察邻接关系的建立过程。

OSPF 路由器之间的邻居关系并不等于邻接关系。邻居关系建立后,还需完成链路状态信息的交换,然后才能建立起邻接关系

在广播网络中,DRothers 之间不需要交换 LSA(Link State Advertisement),DRothers 是通过 DR/BDR 来获取整个广播网络的链路状态信息的,所以 DRothers 之间不需要建立邻接关系,只需要建立邻居关系即可

在 R1、R2、R3、SW 组成的广播网络中, R3 是 DR, R2 是 BDR,只有 R1 是 DRothers, 所以不便于观察 DRothers 之间的邻居关系。现在,将 R1 的 GE 0/0/0 和 R2 的 GE 0/0/0 接口优先级的值改为 0,放弃 DR 的选举,使它们都成为 DRothers,以便观察它们之间的 OSPF 邻居关系。

[R1]interface GigabiEthernet0/0/0
[R1- GigabiEthernet0/0/0]ospf dr-priority 0
[R2]interface GigabiEthernet0/0/0
[R2- GigabiEthernet0/0/0]ospf dr-priority 0

重启 R1 和 R2 上的 OSPF 进程后,先在 DR 路由器 R3 上查看 OSPF 的邻居建立情况。

<R3>display ospf peer

R1 与 DR 路由器 R3 建立的是邻接关系,状态为 full。在路由器R1上查看OSPF邻居关系建立情况。

<R1>display ospf peer

R1与DR路由器R3建立的是邻接关系,状态为full,而与DRothers路由器R2只建立了邻居关系,状态为2-way。

4.4 观察点到点网络中OSPF邻居关系建立情况

开启R1上的两个串口Serial0/0/1和Serial0/0/0,然后关闭广播接口GE0/0/0。关闭广播接口的目的是突出所要关注的实验现象,排除干扰因素。

[R1]interface Serial 0/0/1 

[R1-Serial0/0/1]undo shutdown 

[R1-Serial0/0/1]interface Serial 0/0/0 

[R1-Serial0/0/0] undo shutdown 

[R1]interface GigabiEthernet0/0/0 

[R1- GigabiEthernet0/0/0]shutdown

在R1上查看OSPF邻居建立情况。

<R1>display ospf peer brief

R1 与 R4 和 R5 已经分别建立了邻接关系。

在路由器R1上重启OSPF进程,通过Debugging调试观察R1与R4之间的OSPF邻居邻接关系的建立过程。

<R1>debugging ospf packet

<R1>reset ospf process

R1和R4的邻居关系由full状态转到down状态,经过Hello报文通信后,又变为init状态,继而通过2-way、exchange、loading等状态,再次进入到full状态。

即:点到点网络里面,能够建立OSPF邻居关系的路由器一定会继续建立邻接关系

4.5观察OSPF链路状态数据库的同步过程

下面通过查看报文的方式来简单观察一下 OSPF 邻接关系建立过程中链路状态数据 库 LSDB 是如何同步的,这里仅以点到点网络为例进行实验。 在 R1 的 Serial 0/0/1 接口上捕获并查看报文,重启 R1 上的 OSPF 进程。

debugging ospf packet 

reset ospf process

在第一次交互报文时可以看到I,M,MS都为1.R1和R4都宣称自己为主路由器。

5.思考

1.在 OSPF 广播型网络中的 DR 与 BDR 之间需要建立 OSPF 邻接关系吗?为什么?

需要。只有建立邻接关系的路由器之间才能够同步LSDB。BDR是备份的DR,必须要和DR之间同步。如果DR故障,BDR必须要在其失效时接替他的工作,因此建立邻接关系是必要的,

2.按照 OSPF 的网络设计要求,不同普通区域 Area 之间的通信必须经骨干区域 Area 0 中转才能实现,这种要求的出发点是什么?

OSPF最短路径优先时针对区域内的,区域间采用d-v算法,可能会有环路。因此让哦偶同区域经过骨干区域,可以有效地防止环路的出现。

基于 OSPF 路由的邻居邻接关系发现实践的更多相关文章

  1. QCon技术干货:个推基于Docker和Kubernetes的微服务实践

    2016年伊始,Docker无比兴盛,如今Kubernetes万人瞩目.在这个无比需要创新与速度的时代,由容器.微服务.DevOps构成的云原生席卷整个IT界.在近期举办的QCon全球软件开发大会上, ...

  2. 基于 Spring Cloud 的微服务架构实践指南(下)

    show me the code and talk to me,做的出来更要说的明白 本文源码,请点击learnSpringCloud 我是布尔bl,你的支持是我分享的动力! 一.引入 上回 基于 S ...

  3. 基于Armitage的MSF自动化集成攻击实践

    基于Armitage的MSF自动化集成攻击实践 目录 0x01 实践环境 0x02 预备知识 0x03 Armitage基础配置 0x04 Nmap:Armitage下信息搜集与漏洞扫描 0x05 A ...

  4. 【转帖】基于Zookeeper的服务注册与发现

    http://www.techweb.com.cn/network/hardware/2015-12-25/2246973.shtml 背景 大多数系统都是从一个单一系统开始起步的,随着公司业务的快速 ...

  5. 《数据分析实战:基于EXCEL和SPSS系列工具的实践》一1.4 数据分析的流程

    本节书摘来华章计算机<数据分析实战:基于EXCEL和SPSS系列工具的实践>一书中的第1章 ,第1.4节,纪贺元 著 更多章节内容可以访问云栖社区"华章计算机"公众号查 ...

  6. OSPF路由汇总

    转载自红茶三杯博客:http://blog.sina.com.cn/s/blog_5ec353710102vtfy.html 1. 关于路由汇总 路由汇总,又被称为路由聚合(Route Aggrega ...

  7. 字节跳动流式数据集成基于Flink Checkpoint两阶段提交的实践和优化

    背景 字节跳动开发套件数据集成团队(DTS ,Data Transmission Service)在字节跳动内基于 Flink 实现了流批一体的数据集成服务.其中一个典型场景是 Kafka/ByteM ...

  8. 基于 Apache Hudi 极致查询优化的探索实践

    摘要:本文主要介绍 Presto 如何更好的利用 Hudi 的数据布局.索引信息来加速点查性能. 本文分享自华为云社区<华为云基于 Apache Hudi 极致查询优化的探索实践!>,作者 ...

  9. atitit.基于http json api 接口设计 最佳实践 总结o7

    atitit.基于http  json  api 接口设计 最佳实践 总结o7 1. 需求:::服务器and android 端接口通讯 2 2. 接口开发的要点 2 2.1. 普通参数 meth,p ...

随机推荐

  1. prometheus+grafana实现服务监控

    一.安装prometheus: 下载相应的版本 :https://prometheus.io/download/ 解压: Linux:tar -zxvf XXX.tar.gz windows:直接下载 ...

  2. First Linux Centos 7.2 rpm 安装MySQL 5.7

    服务器需要换python环境,手贱重装了,今天凑巧需要测试数据库,花了一个小时搞了一下MySQL安装. 1.删除原有Mariadb 说明:目前centos默认的MySQL是Mariadb,由于习惯了M ...

  3. docker network 参数

    一. 格式 docker network COMMAND 二.COMMAND 讲解 2.1 .docker network connect 格式 docker network connect [OPT ...

  4. YbtOJ#732-斐波那契【特征方程,LCT】

    正题 题目链接:http://www.ybtoj.com.cn/contest/125/problem/2 题目大意 给出\(n\)个点的一棵树,以\(1\)为根,每个点有点权\(a_i\).要求支持 ...

  5. idea使用gitee的小坑

    1. 账号配置 账号配置登陆时提示 *** is not a valid login name: Email support only. 翻译:只能支持邮箱登录 解决方法:在gitee网站上查看自己配 ...

  6. ❤️这应该是Postman最详细的中文使用教程了❤️(新手使用,简单明了)

    ️这应该是Postman最详细的中文使用教程了️(新手使用,简单明了) 在前后端分离开发时,后端工作人员完成系统接口开发后,需要与前端人员对接,测试调试接口,验证接口的正确性可用性.而这要求前端开发进 ...

  7. gin 源码阅读(5) - 灵活的返回值处理

    gin 源码阅读系列文章列表: gin 源码阅读(1) - gin 与 net/http 的关系 gin 源码阅读(2) - http请求是如何流入gin的? gin 源码阅读(3) - gin 路由 ...

  8. 【UE4 C++ 基础知识】<13> 多线程——TaskGraph

    概述 TaskGraph 系统是UE4一套抽象的异步任务处理系统 TaskGraph 可以看作一种"基于任务的并行编程"设计思想下的实现 通过TaskGraph ,可以创建任意多线 ...

  9. 你知道什么是JUC了吗?

    多线程一直Java开发中的难点,也是面试中的常客,趁着还有时间,打算巩固一下JUC方面知识,我想机会随处可见,但始终都是留给有准备的人的,希望我们都能加油!!! 沉下去,再浮上来,我想我们会变的不一样 ...

  10. Java:判断是否相等小记

    Java:判断是否相等小结 对 Java 中的判断是否相等,即判断两数/两对象是否相等,做一个微不足道的小小小小记 == 判断 对于基本类型和引用类型 == 的效果是不同的,如下: 基本类型:比较的值 ...