引入

OPSF是应用最广的路由协议,基本上,所有的IGP用到的都是OSPF,下面我们看看它的“小秘密”

优点:

•没有跳数限制

•使用组播更新变化的路由和网络信息

•路由收敛速度较快

•以开销(Cost)作为度量值

•采用的SPF算法可以有效的避免环路

•在互联网上大量使用,是运用最广泛的路由协议

工作原理

邻居表建立、建立LSA树、LSDB表建立、路由表

OSPF个区域之间通信必须经过区域0

1.邻居发现:以224.0.0.5组播的方式发送Hello报文发现邻居

2.生成自己LSA信息,包含接口状态、链路开销、IP地址和掩码

3.同步LSDB,也就是相互交换LSA

4.用SPF算法计算路由,以自己为节点计算最短路径树

环路避免

区域内采用SPF算法,树型拓扑,避免环路;
区域间采用星型拓扑,避免环路;

分区结构

不同区域之间通信必须通过骨干区域通信,就算两个区域直连也无法通过OSPF通信;

边界路由器之间采用路由汇总,减少地址震荡的影响;
减少区域内的LSDB中的链路状态信息,这样就减少了对设备性能的要求;

路由器类型

区域内路由器(Internal Router):路由器全部接口处于一个区域内;

区域边界路由器(ABR,Area Border Router):连接骨干区域和非骨干区域的路由器;

骨干路由器(BR,Backbone Router):有接口在骨干区域的路由器;

自治系统边界路由器(ASBR,Autonomous System Border Router ):连接不同协议的路由器;

Route ID

运行OSPF必须得有,32位无符号比特,可以手工配置也可以,自动生成;

自动生成规则: 1、有Loopback接口,选最大的位Route ID

2、不管IP接口是否UP,选IP地址最大的为Route ID(思科、锐捷选UP接口中IP地址最大的)

网络类型

Broadcast(广播型网络),可以用组播224.0.0.5和224.0.0.6发送协议报文

以太网和FDDI时使用

*NBMA (Non-Broadcast Multi-Access,非广播多点可达网络),帧中继和ATM

*P2MP(Point-to-MultiPoint,点到多点)

P2P(Point-to-Point,点到点),PPP,HDLC链路层协议,组播224.0.0.5

报文类型

报文类型

作用

Hello

建立邻居关系

Database Description(DD或DBD)

包含LSDB中的LSA的所有数据

Link State Request(LSR)

收到DBD后跟自己的数据库比较
然后请求自己没有的链路状态或
者比自己更新的详细信息

Link State Update (LSU)

链路状态更新信息,回应Resquest

Link State Acknowledge(LSAck)

对LSU报文进行确认

OSPF被IP协议封装不在TCP层封装怎么保证可靠性

1.Hello:运行OSPF后会在区域不断发送Hello包
2.DDB:设置序列号保证可靠性
3.LSR:发送LSR报文后需要得到LSU回应,如果超时没有收到则继续发送LSR

4.LSU:LSAck确认报文

DR/BDR选举

只有在广播型网络和NBMA网络采用DR选举

1.首先比较Hello报文中携带的优先级优先级最高的被选举为DR,优先级次高的被选举为BDR-------优先级为0的不参与选举

2.优先级一致的情况下,比较Router IDRouter ID越大越优先

保持稳定原则当DR/BDR已经选举完毕,就算一台具有更高优先级的路由器变为有效,也不会替换该网段中已

经选举的DR/BDR成为新的DR/BDR。

选举DR过于浪费时间,一般采用点到点网络代替以太网把连接改成p2p节省时间

邻接关系建立过程

1.在邻居失效时间里面没有收到Hello包,为Down(稳定状态)

路由器互相发送Hello包发现自己不在邻居表中,进入Init状态

2.双方相互发送Hello包,收到Hello包后确认对方在邻居表中,进入2-way(稳定状态)

3.接着发送空的DBD包,比较Route ID,进入ExStart(确定主从关系)

4.交换DBD报文,进入Exchange

5.双方比较DBD报文和自己LSDB的信息,进入Loading,发现DBD有自己没有LSA放LSR请求

6.接收方接收到LSR,然后发送LSU

7.发送方接收LSU,同步完发送LSAck,进入Full

LSDB更新:

老化机制,默认1h,若该LSA在1h内没有更新则丢弃

默认情况,0.5h会刷新一次所有LSA,LSA序列号加1,刷新老化时间

 

补充说明

三种路由实现控制流量配置方法

静态路由

RIP

OSPF

配置优先级

配置掩码

设置开销

走过路过,点个三连,十分感谢

一起学习,一起进步

技术交流:QQ---1740602259

“路由大当家”OSPF的小秘密的更多相关文章

  1. 数据路由通信--ospf复习

    数据路由通信--ospf 复习 ospf 复习 今天来回顾一下ospf ospf全名叫做开放式最短路径优先协议,它是一种基于链路状态的内部网关路由协议.ospf支持区域的划分,内部的路由器使用spf最 ...

  2. CISCO 动态路由(OSPF)

    OSPF(开放式最短路径优先):是一个内部网关协议(Interior Gateway Protocol,简称IGP),用于在单一自治系统(autonomous system,AS)内决策路由.是对链路 ...

  3. 浅谈-动态路由之OSPF的理解

    路由 在网络中,路由相当于就是一张地图,让路由器知道这个对应的IP数据包应该往哪端口.网段走:而这个"地图"我们称之为路由表,不同的目的IP路由表的下一个跳也不同,其生成方式有又有 ...

  4. 关于ros里ppp拨号隧道比如pptp,l2tp,sstp等等,造成多条路由,ospf的时候需要汇总为一条宣告的解决方案

    官方解决方案: https://wiki.mikrotik.com/wiki/OSPF_and_PPPoE_Setup 实际解决步骤: So to get rid of /32 routes * on ...

  5. RIP、OSPF、BGP、动态路由选路协议、自治域AS

    相关学习资料 tcp-ip详解卷1:协议.pdf http://www.rfc-editor.org/rfc/rfc1058.txt http://www.rfc-editor.org/rfc/rfc ...

  6. CCNP路由实验(2) -- OSPF

    OSPF作为一种内部网关协议(IGP),用于在同一个AS中的路由器之间交换路由信息.OSPF的特性如下:1.可适应大规模网络2.收敛速度快3.无路由环路4.支持VLSM和CIDR5.支持等价路由6.支 ...

  7. OSPF的特征、术语、包类型、邻居关系的建立、RID的选择、DR和BDR的选举、度量值的计算、默认路由、验证

    链路状态路由协议OSPF的特征.术语.包类型.邻居关系的建立.RID的选择.DR和BDR的选举.度量值的计算.默认路由.验证等. 文章目录 [*1*].链路状态路由协议概述 工作过程 优缺点 [*2* ...

  8. 静态路由、RIP、OSPF、BGP

      主要内容包含以下四点:(1)静态路由 (2)动态路由 (3)生成树 (4)VLAN 1.  什么是静态路由? 答:静态路由是管理人员手动配置和管理的路由 2.  静态路由由那些优点? 答:配置简单 ...

  9. 动态路由 - OSPF 一文详解

    动态路由 在之前的文章中,介绍了基于距离矢量的路由协议.而在今天这这一部分中会主要讲解链路状态的路由协议,对于动态的路由协议来说,需要具备如下的能力: 发现远端网络 路由器可以直接获得直连路由,这是由 ...

随机推荐

  1. PHP strtoupper() 函数

    实例 把所有字符转换为大写: <?php高佣联盟 www.cgewang.comecho strtoupper("Hello WORLD!");?> 定义和用法 str ...

  2. DataGrip,一款数据库客户端工具,IDEA的兄弟是真香!

    DataGrip 是一款数据库管理客户端工具,方便的连接到数据库服务器,执行sql语句.创建表.创建索引以及导出数据等. DataGrip 支持几乎所有主流的关系数据库产品,如 DB2.Derby.H ...

  3. Linux无名管道通信介绍

    Linux下无名管道一般仅用于父子进程间的通信: 测试代码如下 //file name: fifo_test.c #include <sys/prctl.h> #include " ...

  4. Java实现邮箱验证码

    前言 相比于java实现短信验证码,邮箱验证码就简单了许多,目前只是简单的利用java发送自定义内容至指定邮箱,等过几天再弄短信和邮箱验证码Web版本的.查询网上资料,得知相比于网易邮箱,QQ邮箱是最 ...

  5. PHP7 生产环境队列 Beanstalkd 正确使用姿势

    应用场景 为什么要用呢,有什么好处?这应该放在最开头说,一件东西你只有了解它是干什么的,适合干什么,才能更好的与自己的项目相结合,用到哪里学到哪里,学了不用等于不会,我们平时就应该多考虑一些这样的问题 ...

  6. java引用数据类型之Scanner与Random

    一 Scanner类 引用数据类型的使用 与定义基本数据类型变量不同,引用数据类型的变量定义及赋值有一个相对固定的步骤或格式. 数据类型  变量名  =  new 数据类型(); 每种引用数据类型都s ...

  7. C#LeetCode刷题之#191-位1的个数(Number of 1 Bits)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/4052 访问. 编写一个函数,输入是一个无符号整数,返回其二进制表 ...

  8. C#LeetCode刷题之#874-模拟行走机器人​​​​​​​(Walking Robot Simulation)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/4038 访问. 机器人在一个无限大小的网格上行走,从点 (0, 0 ...

  9. C#LeetCode刷题之#374-猜数字大小(Guess Number Higher or Lower)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3993 访问. 我们正在玩一个猜数字游戏. 游戏规则如下: 我从 ...

  10. C#LeetCode刷题之#633-平方数之和( Sum of Square Numbers)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3885 访问. 给定一个非负整数 c ,你要判断是否存在两个整数 ...