接第六天

OSPF与RIP的不同点

结构化部署 --- 划分区域。

区域划分

区域划分的主要目的

--- 区域内部传递拓扑信息,区域之间传递路由信息。 --- 链路状态型协

议的距离矢量特征--------属于无类别路由协议的原由。

单区域OSPF网络;

多区域OSPF网络。

区域边界路由器

ABR --- 同时属于多个区域,一个接口对应一个区域,必须有一个接口在区域0中,将区域内的拓扑信息收集计算成路由信息,之后进行传递。

区域之间可以存在多个ABR设备,一个ABR设备可以处于多个区域。

区域划分的要求:

必须存在ABR设备;

星型拓扑的中间区域 --- 骨干区域。为了方便区分和标识不同的区域,所以,我们给每一个区域都定义一个区域ID --- area id

OSPF的数据包

1. hello包

作用:周期性的发现,建立和保活邻居关系。

hello包的发送周期 --- hello时间 --- 10S(以太网)/30S

死亡时间 --- dead time --- 4倍的hello时间

RID

区分和标识不同的路由器 --- 本质由32位二进制构成 --- 1,格式统一;2,全网唯一。

RID的生成方式:

手工配置

自动生成 --- 首先,设备将优先选择环回接口的IP地址作为RID,如果存在多个环回接口,则将选择所有环回接口中IP地址最大的作为RID;如果没有配置环回接口,则将使用设备的物理接口的IP地址作为RID,如果物理接口存在多个,则选择IP地址最大的作为RID;

2.DBD包

------- 数据库描述报文 --- LSDB --- 链路状态数据库 --- LSA ---- “菜单”

3.LSR包

------ 链路状态请求报文 --- 基于DBD包,请求未知的LSA信息。 --- “点菜”

4.LSU包

------ 链路状态更新报文 --- 真正携带LSA的数据包 --- “上菜”

5.LSACK包

------ 链路状态确认报文 --- 确认包

OSPF协议具有周期更新机制,每个30MIN发送一次

OSPF的状态机

过程图解:




ospf为什么不用掩码 ospf协议为什么要划分区域_ospf为什么不用掩码


hello包:

标志着邻居关系的建立。

保活。


ospf为什么不用掩码 ospf协议为什么要划分区域_网络_02


DBD包:

主从关系选举 --- 通过发送没有携带数据的DBD包来进行主从关系选举,比较RID来进行选举,RID大的为主,为主可以优先进入后面的状态。

之所以使用DBD包主要是为了和之前的邻居关系进行区分。


ospf为什么不用掩码 ospf协议为什么要划分区域_Powered by 金山文档_03


LSR包:

标志着邻接关系的建立。 ---- 主要目的是为了和之前的邻居关系进行区分,邻居只

能通过hello包进行保活,而邻接之间,可以交换LSA信息。

状态机工作过程

第一步:

down状态 --- 启动ospf之后,发出hello包就进入了下一个状态

第二步:

init(初始化)状态 --- 收到对方的hello包中包含自己本地的RID,则进入到下一个状态

标志着邻居关系的建立

匹配成功,则进入到下一个状态;失败则停留在邻居状态,仅使用hello包进行周期保活

第三步:

exstart(预启动)状态 --- 通过发送没有携带数据的DBD包来进行主从关系选举,比较RID来

进行选举,RID大的为主,为主可以优先进入后面的状态

第四步:

exchange(准交换)状态 --- 交换携带数据(摘要信息)的DBD包进行LSDB数据库目录共享

第五步:

loading(加载)状态 --- 基于对端发送的DBD包,使用LSR/LSU/LSACK交换未知的LSA信息

第六步:

FULL状态 --- 标志着邻接关系的建立。

OSPF的工作过程

1.建立邻居表

将收集到的邻居关系记录在一张表中 --- 邻居表;邻居关系建立完成后,进行条件匹配。失败则停留在邻居关系,仅hello包进行保活

2.建立数据库表

开始建立邻接关系。首先,使用未携带数据的DBD包进行主从关系选举。之后,使用携带数据的DBD包共享目录信息,之后,基本DBD包,通过LSR/LSU/LSACK获取未知的LSA信息。将所有的LSA信息保存本地的LSDB数据库 --- 数据库表;

3.最后

路由表。

发送hello包进行保活,每30min一次周期更新。

结构突变:

1,突然新增一个网段:触发更新,第一时间将变更信息通过LSU包传递出去,需要ACK确认

2,突然断开一个网段:触发更新,第一时间将变更信息通过LSU包传递出去,需要ACK确认

3,无法联系

OSPF的基本配置

1,启动OSPF进程

[r1]ospf 1 router-id 1.1.1.1 --- 手工配置RID需要在进程启动时配置

[r1-ospf-1]

2,创建区域

[r1-ospf-1]area 0

[r1-ospf-1-area-0.0.0.0]

3,宣告
宣告的作用:

1,激活接口

2,发布路由

[r1-ospf-1-area-0.0.0.0]network 1.1.1.1 0.0.0.0

0.0.0.0 --- 反掩码 --- 由连续的0和连续的1组成,0对应位不可变,1对应位可变。

查看操作:

display ospf peer

display ospf peer brief --- 查看邻居关系简表

display ospf lsdb --- 查看数据库表

display ospf lsdb router 2.2.2.2

display ip routing-table protocol ospf

COST值的计算:

COST = 参考带宽 / 真实带宽 --- 华为设备默认的参考带宽为100Mbps

小于1的小数,则直接按照1来算。如果是一个大于1的小数,只取整数部分。

bandwidth-reference 1000

条件匹配

DR

指定路由器 --- 和广播域内其他设备建立邻接关系

BDR

备份指定路由器 --- 和广播域内其他设备建立邻接关系,称为DR设备的备份。一个广播域内部,至少需要4台设备才能看到邻居关系。DR和BDR其实是接口的概念

条件匹配的内容

--- 在一个广播域中,若所有设备均为邻接关系,将出现大量的重复更新;故需要进行DR/BDR的选举,所有DRother之间,仅维持邻居关系即可。

DR/BDR的选举规则

1.比较优先级

华为设备,OSPF协议的默认优先级为 -- 10

先比较优先级,优先级最大的为DR,次大的为BDR;

优先级默认为1 --- 主要目的让人为修改

ospf dr-priority ?

INTEGER<0-255> Router priority value

注意:如果将一个接口的优先级设置为0,则代表这个接口将放弃DR/BDR的选举。

2,手工汇总 --- 区域汇总

ABR设备上进行配置

abr-summary 192.168.0.0 255.255.254.0

3,沉默接口

只接受不发送路由信息

silent-interface GigabitEthernet 0/0/2

4,加快收敛 --- 减少计时器的时间

ospf timer hello 5 --- 修改hello时间的方法

ospf timer dead ?

INTEGER<1-235926000> Second(s)

注意:邻居双方的hello时间和死亡时间必须相同,否则将断开邻居关系

5,缺省路由

default-route-advertise

注意:这个命令要求边界设备自身得具有缺省路由才行

default-route-advertise always --- 在没有缺省的情况下,强制下发缺省

ACL --- 访问控制列表

ACL访问控制列表的作用:

1,访问控制

接口上,匹配流量,然后执行设定好的动作 ---permit(允许), deny(拒绝)。

2,抓取感兴趣流

只负责抓取流量,动作由其他服务来执行。

ACL列表的匹配规则

自上而下,逐一匹配。如果匹配到了,则执行对应的动作,则不再向下匹配。

思科 --- ACL列表末尾默认包含一条拒绝所有的规则。

华为 --- ACL列表末尾没有包含任何规则。

ACL列表的分类

第一类:

源IP地址 --- “只关注你是谁”

第二类:

源IP地址,还关注目标IP地址,以及协议和端口号 ---“不仅 关注你是谁,还关注你去哪,干啥”

第三类:二层ACL
第四类:用户自定义ACL列表