CCNA 之 七 路由协议 三 OSPF
OSPF协议
OSPF
开放式最短路径优先
全称:Open Shortest Path First
是目前使用最为广泛的路由协议,主要因为OSPF
是开放式协议,和IGRP
、EIGRP
思科的私有协议不同。
接口敏感型的协议;
链路状态路由协议
特点:
- 是一种链路状态路由协议,无路由环路(全局拓扑),
RFC2328
- "开放"意味着非私有的
所有的厂商都可以使用的公有化的协议;
- 管理型距离:110(AD值)
- OSPF采用SPF算法计算达到目的地的最短路径
什么叫链路(LINK)? = 路由器接口
什么叫状态(State)? = 描述接口以及其与邻居路由器之间的关系
OSPF metric
每个路由器都把自己当做根,并且给予累计成本
Cost
值来计算到达目的地的最短路径
Cost = 参考带宽(10^8) / 接口带宽(b/s)
OSPF metric详细的计算方式:
进来一条路由的所有路由器的如接口方向的累计;
OSPF报文类型
- Hello 简历和维护
OSPF
邻居关系 - DBD 链路状态数据库描述信息(描述
LSDB
中LSA
头部信息) - LSR 链路状态请求,向
OSPF
邻居请求链路状态信息 - LSU 链路状态更新(包含一条或多条
LSA
) - LSAck 对
LSU
中的LSA
进行确认。
OSPF区域
- 在区域边界可以做路由汇总,减小了路由表
- 减少了
LSA
洪范的范围,有效的把拓扑变化控制在区域内,提高了网络稳定性 - 拓扑的变化影响可以只限制涉及本区域内
- 多区域提高了网络的扩展性,萝莉与组件大规模网络
OSPF的三张表
- 邻居表(neighbor table):
OSPF
用邻居机制来发现和维护路由表的存在,邻居表存储了双向通信的邻居关 系OSPF
路由器列表的信息。
- 拓扑表(topology table):
OSPF
用LSA
(Link state Advertisement 链路状态通告)来描述网络拓扑信息,然后OSPF
路由器用拓扑数据库来存储网络的这些LSA
信息
- OSPF路由表(routing table)
对链路状态数据库进行
SPF
(Dijkstra)计算,而得出的OSPF
路由表。
OSPF基本的运行步骤:
- 步骤1、建立邻居关系(Establish route adjacencies)
- 步骤2、必要的时候进行DR的选举(Elect the DR / BDR)
- 步骤3、发现路由(Discover routes)
- 步骤4、选择合适的路由器(Select appropriate route)
- 步骤5、维护路由信息(Maintain routing infomation)
一、建立邻居关系
下图中为OSPF
在建立邻居关系发送的Hello
包中的数据
Hello
包用来发现OSPF
邻居关系并建立相邻关系,通过组播地址224.0.0.5
来给ALLSPFRroutes- 通告两台路由器建立相邻关系必要的统一的参数。
- 在以太网和帧中继网络等多路由访问网络中选举制定路由器(DR)和备用制定路由器(DBR)
OSPF的网络类型
BMA
广播性多路访问Point-to-Point
点对点NBMA
非广播型多路访问
以上三种是根据某一个路由器接口的二层封装来识别这个路由器的这个接口应该是
OSPF
的网络类型,从而影响到OSPF
在这个接口上运转.
- 点对多点
不是路由器自己设别,需要手工配置
LSA的泛洪解决方式:
选举
DR
和BDR
这里需要注意:DR
和BDR
的选举,只在以太网(MA)或者是Frame relay
的方式才会进行,并且DR
和BDR
的选举,会影响路由器之间建立邻居关系的时间,因为在建立邻居关系的时候,会穿插着进行DR
和BDR
的选举。
- 为减小多路访问网络中的OSPF流量,
OSPF
会选举一个制定路由器(DR)和一个备用制定路由器(BDR) - 选举规则:最高接口优先级被选作DR,如果优先级相等(默认为1),具有最高的路由器
ID
(Router-ID)的路由器被选举程DR
,并且DR
具有非抢占性 - 制定路由器(DR):
DR
负责使用该变化信息更新其他所有OSPF
路由器(DRouter) - 备用制定路由器(BDR):
BDR
会监控DR
的状态,并在当前DR
发生故障时接替其角色
RouterID
用于表示OSPF路由器的ID,全网唯一性;可手动配置,也可动态选举(有Loopback接口时,选择最高的Loopback IP地址;否则,选择最高活跃物理接口的IP地址)。
LSA泛洪
当网络中某一台路由器R1线路发生变化时,R1会通过组播地址
224.0.0.6
发送通知LSA
,而一个OSPF
网络环境中,只有DR
和BDR
会监听这个地址,也就是说该网络中,只有DR
和BDR
会接收到通知
DR接收到后,再通过组播地址224.0.0.5
发送变更通知LSU
,改地址代表网络中所有运行OSPF
协议的路由器都会监听224.0.0.5
地址,并受到通知
路由器收到包含变化后的LSA
的LSU
后,更新自己的链路状态数据库,过一段时间(SPF延迟),对更新的链路状态数据库执行SPF
算法,必要时更新路由表。
OSPF基本配置
- 开启OSPF进程
- 宣告特定的网络到OSPF区域
通配符掩码
通配符是一个用于决定哪些IP地址位该精确匹配(0代表精确匹配)哪些地址被忽略的32位数值,通常用于处理访问控制列表(ACL)、OSPF和EIGRP等路由协议的网络通告。
掩码:1位表示网络号;0位表示主机位。掩码用于区分IP地址中的网络及主机部分
通配符:1位表示无所谓;-位表示需要严格匹配。通配符用于决定一个IP钟的那些为该匹配
下面是实际配置:
根据下图中的拓扑配置OSPF
R1配置:
R1>en
R1#conf t
R1(config)#int s 0/0
R1(config-if)#ip add 192.168.1.1 255.255.255.0
R1(config-if)#no sh
R1(config-if)#
R1(config-if)#ex
R1(config)#router ospf 1
R1(config-router)#network 192.168.1.0 0.0.0.255 area 0
R2配置:
R2>en
R2#conf t
R2(config)#int s 0/0
R2(config-if)#ip add 192.168.1.2 255.255.255.0
R2(config-if)#no sh
R2(config-if)#ex
R2(config)#int s 0/1
R2(config-if)#ip add 192.168.2.1 255.255.255.0
R2(config-if)#no sh
R2(config-if)#ex
R2(config)#router ospf 1
R2(config-router)#network 192.168.1.0 0.0.0.255 area 0
*Mar 1 00:05:06.847: %OSPF-5-ADJCHG: Process 1, Nbr 192.168.1.1 on Serial0/0 from LOADING to FULL, Loading Done # 这里提示邻居关系已经建立
R2(config-router)#network 192.168.2.0 0.0.0.255 area 0
R3配置:
R3>en
R3#conf t
R3(config)#int s 0/0
R3(config-if)#ip add 192.168.2.2 255.255.255.0
R3(config-if)#no sh
R3(config-if)#ex
R3(config)#router ospf 1
R3(config-router)#network 192.168.2.0 0.0.0.255 area 0
*Mar 1 00:06:41.635: %OSPF-5-ADJCHG: Process 1, Nbr 192.168.2.1 on Serial0/0 from LOADING to FULL, Loading Done # 这里提示邻居关系已经建立
验证:
R1:
R1#show ip route
Codes: C - connected, S - static, R - RIP, M - mobile, B - BGP
D - EIGRP, EX - EIGRP external, O - OSPF, IA - OSPF inter area
N1 - OSPF NSSA external type 1, N2 - OSPF NSSA external type 2
E1 - OSPF external type 1, E2 - OSPF external type 2
i - IS-IS, su - IS-IS summary, L1 - IS-IS level-1, L2 - IS-IS level-2
ia - IS-IS inter area, * - candidate default, U - per-user static route
o - ODR, P - periodic downloaded static route
Gateway of last resort is not set
C 192.168.1.0/24 is directly connected, Serial0/0
O 192.168.2.0/24 [110/128] via 192.168.1.2, 00:00:05, Serial0/0
R1#ping 192.168.2.2
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 192.168.2.2, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 8/14/32 ms
R3:
R3#show ip route
Codes: C - connected, S - static, R - RIP, M - mobile, B - BGP
D - EIGRP, EX - EIGRP external, O - OSPF, IA - OSPF inter area
N1 - OSPF NSSA external type 1, N2 - OSPF NSSA external type 2
E1 - OSPF external type 1, E2 - OSPF external type 2
i - IS-IS, su - IS-IS summary, L1 - IS-IS level-1, L2 - IS-IS level-2
ia - IS-IS inter area, * - candidate default, U - per-user static route
o - ODR, P - periodic downloaded static route
Gateway of last resort is not set
O 192.168.1.0/24 [110/128] via 192.168.2.1, 00:00:14, Serial0/0
C 192.168.2.0/24 is directly connected, Serial0/0
R3#ping 192.168.1.1
Type escape sequence to abort.
Sending 5, 100-byte ICMP Echos to 192.168.1.1, timeout is 2 seconds:
!!!!!
Success rate is 100 percent (5/5), round-trip min/avg/max = 8/18/36 ms
此时可以看到192.168.1.0/24
和192.168.2.0/24
网段都能互通,完成。
CCNA 之 七 路由协议 三 OSPF的更多相关文章
- 路由协议之OSPF
目录 OSPF协议 OSPF的七种状态 OSPF的11种LSA Stub和Nssa OSPF中的防环机制 OSPF中的路由汇总和路由过滤 OSPF中的虚拟链路 虚拟链路有两种存在的意义 OSPF中的认 ...
- rip是典型的距离矢量动态路由协议。Ospf是链路状态型的协议
网络工程师十个常见面试问题-看准网 https://m.kanzhun.com/k-mianshiwenti/1465113.html 两者都属于IGP协议,rip是典型的距离矢量动态路由协议.Osp ...
- 详解 CSS 七种三栏布局技巧
作者:林东洲 链接:https://zhuanlan.zhihu.com/p/25070186 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 三栏布局,顾名思义就是 ...
- css中常用的七种三栏布局技巧总结
三栏布局,顾名思义就是两边固定,中间自适应.三栏布局在开发十分常见,那么什么是三栏布局?例如当当网首页边商品导航和右边导航固定宽度,中间的主要内容随浏览器宽度自适应.效果如下图所示: 下面围绕的这样的 ...
- CCNA 之 六 路由协议 二 EIGRP
EIGRP(Enhanced IGRP) 增强型内部网关路由协议 注意:这是cisco私有协议:也就是说,该协议只能运行在思科的设备上,如果有其他的厂家的设备,则不能保证能运行此协议: EIGRP的特 ...
- CCNA 之 五 路由协议 一 静态路由
静态路由 路由选择原理 什么是路由? 就如同去某一个地方,会有很多种路线,每一条路线经都可以称之为路由: 路由器中会维护一张路由表,每一个表项都是一条路由,也就是去往某个网络的路径,然后将对应的数据包 ...
- Mybatis框架七:三种方式整合Spring
需要的jar包: 新建lib文件夹放入jar包,Build Path-->Add To Build Path之后: 原始Dao开发示例: src下:新建核心配置文件sqlMapConfig.xm ...
- 01-http简介-四层 七层 三次握手
HTTP简介.请求方法与响应状态码 接下来想系统的回顾一下TCP/IP协议族的相关东西,当然这些东西大部分是在大学的时候学过的,但是那句话,基础的东西还是要不时的回顾回顾的.接下来的几篇博客都是关于T ...
- 再见Jenkins,从Gitlab代码提交到k8s服务持续交付只需七毛三(走过路过不要错过)
Gitlab runner 快速搭建CICD pipeline 背景 日常开发中,相信大家已经做了很多的自动化运维环境,用的最多的想必就是利用Jenkins实现代码提交到自动化测试再到自动化打包,部署 ...
随机推荐
- 回话技术-Cookie-记录上一次访问时间
效果: 第一次访问: 再次访问: <%@ page import="java.util.Date" %> <%@ page import="java.t ...
- Shiro笔记---身份验证
1.shiro有哪些主要功能 2.搭建shiro环境(*) idea2018.2.maven3.5.4.jdk1.8 项目结构: pom.xml: <dependencies> < ...
- Web for pentester_writeup之XML attacks篇
Web for pentester_writeup之XML attacks篇 XML attacks(XML攻击) Example 1 - XML外部实体注入(XXE) Payload http:// ...
- python 爬取网页简单数据---以及详细解释用法
一.准备工作(找到所需网站,获取请求头,并用到请求头) 找到所需爬取的网站(这里举拉勾网的一些静态数据的获取)----------- https://www.lagou.com/zhaopin/Pyt ...
- Angular开发规范
目录 一. 前言 1.1. 规范目的 1.2. 局限性 二. 文件规范 2.1. 文件结构约定 2.2. 单一职责原则 ...
- JavaSE(下)
11.抽象的(abstract)方法是否同时是静态的(static),是否可同时是本地方法(native),是否可同时被synchronized? 都不能. 抽象方法需要子类重写,而静态的方法是无法被 ...
- Feign设置assessToken
import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.an ...
- MySQL系列:一句SQL,MySQL是怎么工作的?
对于MySQL而言,其实分为客户端与服务端. 服务端,就是MySQL应用,当我们使用net start mysql命令启动的服务,其实就是启动了MySQL的服务端. 客户端,负责发送请求到服务端并从服 ...
- 008.Kubernetes二进制部署Nginx实现高可用
一 Nginx代理实现kube-apiserver高可用 1.1 Nginx实现高可用 基于 nginx 代理的 kube-apiserver 高可用方案. 控制节点的 kube-controller ...
- Python 基础之 I/O 模型
一.I/O模型 IO在计算机中指Input/Output,也就是输入和输出.由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘.网络等,就需要IO接 ...