HCIP--ospf总结

一.OSPF基础

OSPF: 开放式最短路径优先协议

无类别IGP协议;链路状态型; 基于LSA收敛,故更新量较大,为在中大型网络正常工作,需要进行结构化的部署 --- 区域划分、ip地址规划

组播更新 --- 224.0.0.5 224.0.0.6 支持等开销负载均衡

支持触发更新 30min周期更新 跨层封装协议,协议号89;

    • 数据包 --- 5种

Hello --- 邻居的发现,关系的建立,周期保活

DBD --- 数据库描述包

LSR --- 链路状态请求

LSU --- 链路状态更新 -- 携带各种LSA

LSack --- 链路状态确认

    • OSPF状态机

Down 一旦接收到hello包进入下一个状态机

Init 初始化 接收到的hello包中,若存在本地的RID,进入下一状态

2way 双向通讯 -- 邻居关系建立的标志

条件匹配:点到点网络直接进入下一个状态机 MA网络将进行DR/BDR选举(40S)

非DR/BDR之间不能进入下一个状态机

Exstart -- 预启动 使用不携带目录信息的DBD包进行主从关系选举,RID数值大为主,优先进入下一个状态机; 主从目的主要在于信息交互的有序性,避免同时收发造成网络拥塞

Exchange 准交换 -- 使用DBD携带目录信息,进行共享

Loading 加载 -- 查看完邻接的目录信息后,针对本地未知的LSA,使用LSR包进行查询,对端使用LSU进行应答, 本地接收到LSA后使用ack进行确认 --- 获取未知的LSA信息

Full --转发 邻接关系建立的标志

    • OSPF的工作过程

启动配置完成后,邻居间组播收发hello包,建立邻居关系;生成邻居表;

邻居关系建立后,将进行条件的匹配,匹配失败将维持邻居关系,仅hello包周期保活即可;

匹配成功可以建立邻接(毗邻)关系;邻接关系间将使用DBD/LSR/LSU/LSack来获取本地未知的LSA信息;获取完成后,邻接关系间数据库同步一致;--- 数据库表;

之后本地基于本地的数据库所有内容整理出有向图--->最短路径树结构--->将本地到达所有未知网段的最短路径加载于本地的路由表中;

收敛完成后,邻居间仅hello包周期保活即可;每30min邻接关系间周期比对数据库目录,

若不一致将马上使用LSU和LSACK进行不一致部分收敛;

拓扑突变 :

1)新增网段:直连新增网段设备,用LSU直接进行触发更新

2)断开网段:直连断开网段设备,用LSU直接进行触发更新

3)无法沟通:dead time 为hello time4倍;在dead time到时时将断开邻接、邻居关系,删除路由;

    • OSPF的基础配置

[r1]ospf 1 router-id 1.1.1.1 启动时可以定义进程号,进程号仅具有本地意义;

每一个OSPF进程均需要RID,全网唯一;生成顺序-- 手写--环回接口最大数值的ip地址 -- 物理接口上数值最大的ip地址

[r1-ospf-1]

宣告:1)区域划分 2)激活接口--可以收发ospf的信息 3)传递接口信息--该接口信息将被共享给其他邻接

[r1-ospf-1]area 0

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

[r1-ospf-1-area-0.0.0.0]network 12.1.1.0 0.0.0.255

区域划分规则:

  1. 星型拓扑 --- 区域0为骨干,大于0为非骨干,所有非骨干必须连接到骨干区域方可正常共享路由

  1. 区域间必须存在ABR -- 区域边界路由器

启动配置完成后,邻居间组播收发hello包,建立邻居关系;生成邻居表;

[r2]display ospf peer 查看邻居信息

[r2]display ospf peer brief 查看邻居表

5.邻居关系成为邻接关系的条件 --- 和网络类型有关

点到点 --- 所有邻居直接建立为邻接关系

MA---由于OSPF协议需要邻接关系间进行数据库对比,故不支持接口水分割;若两两间均为邻接关系,将可能出现大量的重复更新;因此,在MA网络中ospf协议将进行DR/BDR选举,所有非DR/BDR设备间维持邻居关系,不进行数据库共享;

选举规则:1)先比较参选接口的优先级 0-255 默认为1,大优

2)若优先级相同,比较参选的RID,数值大优

若需要干涉选举,可以修改参选接口的优先级

[r1]int g0/0/1

[r1-GigabitEthernet0/0/1]ospf dr-priority 3

切记:选举是非抢占的,故修改后该网段依然维持原有角色,若希望重新选举,需要重启该网段所有设备的OSPF进程;

<r1>reset ospf process 重启ospf进程

Warning: The OSPF process will be reset. Continue? [Y/N]:y

建议直接将DR优先级修改最大,BDR次大,其他设备优先级修改为0,0标识不参选,可以不同重启任何设备的ospf进程;

二.OSPF接口网络类型

解决方案:

修改接口的ospf工作方式:

1)修改该网段所有接口为 Broadcast

[r1]int t0/0/0

[r1-Tunnel0/0/0]ospf network-type broadcast

切记:由于p2p和 broadcast hello time均为10s,故将能建立邻居关系,但p2p不进行DR/BDR选举,所以建邻后无法正常收敛;因此该网段所有接口必须修改成一样的工作方式;

注解1:在MGRE环境中,若网络拓扑为星型;且所有接口的工作方式,均修改为broadcast;

由于分支站点之间没有伪广播,无法知道对端的存在,故DR/BDR选举将混乱;只能让中心站点成为DR,没有BDR;

2)修改所有接口的工作方式为p2mp

P2MP 工作方式 hello time为30,不进行dr、bdr选举

P2mp是为帧中继这种物理的NBMA网络设计,在MGRE环境中不建议使用

补充内容:

关于MGRE的拓扑
  1. 星型 -- 中心站点固定ip地址,所有分支仅和中心注册

  1. 全连网状 --- 所有站点均为固定ip,所有设备均为中心,两两间均注册

  1. 部分网状 -- 部分设备为固定ip地址,存在部分中心和部分的分支

在以上三种环境中运行OSPF的方案:
  1. 星型 -- 所有接口工作方式为broadcast,仅中心站点为DR,无BDR

  1. 全连 -- 所有接口工作方式为broadcast;DR/BDR将默认自动选举成功

  1. 部分 -- 所有接口工作方式为broadcast;合理安排DR的位置

三.OSPF 扩展知识:

    • OSPF不规则区域

  1. 远离了骨干的非骨干

  1. 不连续骨干

解决目的--全网可达
解决方案:
    • tunnel -- 在合法与非法ABR间使用tunnel建立一个新的网段(类似连接一条独立的网线);然后将该网段宣告到ospf协议中;

缺点:1)选路不佳 2)周期和触发信息对中间穿越区域照成影响

    • OSPF虚链路 -- 合法的ABR与同一区域的非法ABR,建立虚链路;非法ABR获得合法ABR授权后,可进行区域间路由的共享;

[r2]ospf 1

[r2-ospf-1]area 1 两台ABR共同存在的区域

[r2-ospf-1-area-0.0.0.1]vlink-peer 4.4.4.4 对端ABR的RID

两台设备均需配置

优点:由于没有新的网段链路出现,不会像tunnel一样选路不佳;

缺点:周期和触发的信息对中间穿越区域照成影响

cisco系 --- 在虚链路上取消周期更新、周期保活 -- 失去可靠性

华为系 --- 保留周期信息,对中间区域照成影响

3、多进程双向重发布(推荐)

多进程 --- 一台路由器上运行多个OSPF进程,可以分别建立自己的邻居,,每个进程拥有独立的数据库,不共享信息;只是将各自计算所得路由加载于同一张路由表中;类似于在同一台路由器上允许多种动态路由协议的效果;路由器单一一个接口只能工作在唯一一个进程中;

重发布:一个网路中,若同时运行多种路由协议;默认协议间不兼容,无法共享路由;可以在两种协议间配置ASBR,ASBR(自治系统边界路由器,协议边界路由器)必须用不同的接口工作不同的协议中;通过两种协议获取到两边的路由,默认这些路由不共享,重发布技术可以实现路由共享,最终全网可达;

故在不规则区域中,利用多进程加重发布机制,可以实现全网可达,且不存在选路问题和中间区域周期信息相关问题;

多进程双向重发布配置命令

[r4]ospf 1

[r4-ospf-1]import-route ospf 2

[r4-ospf-1]q

[r4]ospf 2

[r4-ospf-2]import-route ospf 1

注:通过重发布手段学习到的ospf路由,显示协议为0_ASE,优先级为150;

    • OSPF的数据库表

查看OSPF数据库目录

<r1>display ospf lsdb

LSDB中装载了所有可以学习到的LSA;

LSA-- 链路状态通告 一条拓扑或一条路由条目被称为一条LSA

OSPF协议的数据库是本地所有LSA的集合,不同网络环境下将产生不同类别的LSA;

LSA在共享时基于LSU数据包传递;

各种类别的LSA;

如何查看一条LSA的具体信息

<r1>display ospf lsdb router 2.2.2.2

类别 link-id

LSA7nssa 单个NSSA区域 ASBR 域外路由 域外路由目标网络号

减少LAS更新量
  1. 汇总 -- 优化骨干区域

  1. 特殊区域 -- 优化非骨干区域

【1】汇总
  1. 域间汇总 ABR设备基于某个区域的1/2类LSA计算所得的最佳路由,共享给其他区域时,进行汇总传递

[r2]ospf 1

[r2-ospf-1]area 1 --明细路由所在区域,该ABR设备必须和明细路由在同一区域

[r2-ospf-1-area-0.0.0.1]abr-summary 1.1.0.0 255.255.252.0

  1. 域外汇总 --- ASBR重发布进入OSPF域路由进行汇总配置

[r6]ospf 1

[r6-ospf-1]import-route rip 重发布RIP路由进入ospf域

在ASBR重发布路由后,同时进行汇总配置

[r6]ospf 1

[r6-ospf-1]asbr-summary 99.1.0.0 255.255.252.0

【2】特殊区域 --- 优化非骨干区域的lsa数量

不是骨干区域,不能存在虚链路

    • 不能存在ASBR

1】末梢区域

该区域将拒绝4、5LSA的进入,同时由该区域连接骨干0区域的ABR向该区域,发布一条3类的缺省路由;

[r1]ospf 1

[r1-ospf-1]area 1

[r1-ospf-1-area-0.0.0.1]stub

该区域内每台路由器均需配置,否则无法正常建立邻居关系

2】完全末梢

在末梢区域的基础上,进一步拒绝3类的LSA,仅保留ABR发送过来的3类缺省;

先将该区域配置为末梢区域,然后仅在ABR上定义完全即可

[r2]ospf 1

[r2-ospf-1]area 1

[r2-ospf-1-area-0.0.0.1]stub no-summary

    • 存在ASBR

1】NSSA -- 非完全末梢区域

该区域拒绝4/5类的LSA;本地的ASBR产生的域外路由基于7类进行传输;当7类LSA需要通过NSSA区域的ABR进入骨干区域,将由该ABR进行7转5,以5类发现骨干区域,7转5的这台ABR同时成为一台ASBR

华为设备由该区域连接骨干ABR自动产生7类缺省路由;

[r4]ospf 1

[r4-ospf-1]area 2

[r4-ospf-1-area-0.0.0.2]nssa 该区域每台设备均需配置

2】完全NSSA

在NSSA的基础上进一步拒绝3类的LSA,由该区域连接骨干的ABR发布一条3类缺省

先将该区域配置为NSSA,然后仅在ABR定义完全即可

[r4-ospf-1-area-0.0.0.2]nssa no-summary

四.OSPF扩展配置

    • 认证

直连的邻居或邻接关系间,进行认证配置后,5种数据包中均携带身份核实的密码,且华为设备会对更新信息进行加密--前提为认证方式选择密文认证

    • 接口认证

[r1-GigabitEthernet0/0/1]ospf authentication-mode md5 1 cipher 123456

直连的邻居间秘钥和编号、模式必须完全一致否则无法建立邻居关系;

    • 区域认证

假设在R1上开启区域0的区域认证,实际就是在R1上所有宣告到区域0接口上配置了接口认证;

[r1]ospf 1

[r1-ospf-1]area 0

[r1-ospf-1-area-0.0.0.0]authentication-mode md5 1 cipher 123456

可以理解为批量的完成了接口认证;

    • 虚链路认证

[r1-ospf-1-area-0.0.0.1]vlink-peer 3.3.3.3 md5 1 cipher 123456

在虚链路的两端配置

    • 沉默接口

只接收不发送路由协议信息,用于路由器连接邻居或邻接的骨干链路,不得用于连接终端用户的接口;

[r1]ospf 1

[r1-ospf-1]silent-interface GigabitEthernet 0/0/2

    • 修改计时器

Ospf的hello time为10s或者30s dead time为hello time的4倍;

邻居间该时间必须一致,否则无法邻居关系;若hello time为10,不再建立修改;

若为30s可以结合网络的实际硬件处理能力,适当修改计时器,加快收敛速度

[r1]int g0/0/1

[r1-GigabitEthernet0/0/1]ospf timer hello 10 修改本端的hello time,本端的dead time自动4倍关系匹配;对端还需要手工修改一致,否则无法建立邻居关系;

[r1-GigabitEthernet0/0/1]ospf timer dead 40 修改本端的dead time,本端的hello time不变

    • 缺省路由

3/5/7类缺省;

3类缺省:

是由配置特殊区域后,特殊区域连接骨干区域的ABR自动发布末梢、完全末梢、完全NSSA;普通NSSA不产生3类缺省;

5类缺省:

[r3-ospf-1]default-route-advertise 将边界路由器上,路由表中通过其他协议产生的缺省路由(最常为静态缺省)重发布到本地的OSPF协议中

因此若边界路由器的路由表还未拥有缺省时,配置该命令将无法发布缺省到其他邻居;

[r3-ospf-1]default-route-advertise always 强制本地向所有邻居重发布缺省路由,即便本地路由表中没有缺省,也会发布;

7类缺省:

配置特殊区域NSSA时,NSSA区域连接骨干的ABR将发布缺省路由;

[r6-ospf-1-area-0.0.0.2]nssa default-route-advertise 由NSSA区域内部存在其他协议获取的缺省路由时,可以重发布到该NSSA区域

切记:由于特殊区域会产生缺省路由指向骨干区域;故必须关注网络中ISP所在的位置,否则可能由于缺省的互指产生环路 --- ISP连接骨干以外的任何区域,那么该区域将不能配置为特殊区域;

五.OSPF的扩展知识点

「1」附录E --- link-id相同的问题

若一台ABR将两条3类LSA导入其他区域;或者一台ASBR将两条5/7类导入OSFP域;

同时这两条LSA的link-id会相同;

假设:短掩码网段先进入,link-id正常显示;长掩码进入时link-id加反掩码

20.1.0.0/16--link-id 20.1.0.0

20.1.0.0/24--link-id 20.1.0.255

若长掩码先进入,再短掩码进入时,长掩码的信息被刷新为反掩码;

「2」OSPF选路规则

    • AD(管理距离)无关的一种情况:

r2(config)#router ospf 1

r2(config-router)#distance 109 1.1.1.1 0.0.0.0

本地从RID为1.1.1.1的设备处学习到路由条目,管理距离修改109;

一台路由器从两个OSPF邻居处学习到了两条相同的路由时,仅比较度量值,不关注管理距离;因为仅针对一台邻居进行管理距离修改的结果是要么两台都被改,要么修改失败;-关注IOS版本---有时修改RID大的路由器管理距离生效,有时需要修改RID小的设备;

    • AD(管理距离)无关的第二种情况 O IA 3类

O IA 与 O IA路由相遇,到达相同目标的两条3类路由,这两条路由均通过非骨干传递,仅关注cost值,不关注管理距离;

若一条通过骨干区域传递,另一条同过非骨干区域传递--非骨干传递的路由无效

OSPF的区域水平分割:区域标号为A的3类LSA,不能回到区域A;

先比类型-à 区域àcost

    • OE 与OE

E为5类 N 为7类 默认所有重发布进入路由条目均为类型2,类型2在路由表中cost值不会显示沿途的累加,仅显示起始度量;

两条均为OE2或者均为N2,起始度量相同; 关注沿途的累加度量(OE2路由在表中度量默认不显示内部度量,仅显示起始度量)

两条均为OE2或者均为N2,起始度量不同;优先起始度量小的路径;

注:以上设计是便于管理员快速干涉选路;

OE1路由仅比较总度量(起始度量+沿途累加),仅修改起始度量不一定能干涉选路,必须在修改后使得总度量产生区别才能干涉选路;

    • 总结

拓扑优于路由 1/2LSA计算所得路由优于3/4/5/7类计算所得

内部优于外部 3类优于4/5/7类

类型1优于类型2 E1优于E2,N1优于N2,E1优于N2,N1优于E2;

E1与N1相遇,或E2与N2相遇,先比总度量(起始+沿途)小优;度量一致5类优于7类重发布进入ospf的路由条目,无论5或7类LSA,均存在一个类型号;默认为类型2,类型2路由仅显示起始度量;修改为类型1后将显示实际度量; 类型2虽然仅显示起始度量,但在选路时,实际比较的是总度量;

【3】FA-转发地址

正常OSPF区域收到的5类LSA不存在FA值;

产生FA的条件:

1、5类LSA

假设R2为ASBR,g0/0口工作的OSPF中,g0/1口工作在非ospf协议或不同ospf进程中;若g0/1也同时宣告在和g0/0相同的OSPF进程中,同时该接口的工作方式为广播型;

将在5类LSA中出现FA地址,地址为R2连接R3网段中R3的接口ip;

2、7类LSA---必然出现FA地址

假设R9为ASBR,S0/0口工作的OSPF中,S0/1口工作在非ospf协议或不同进程中;

S0/1未运行OSPF--FA地址为R9上最后宣告的环回地址(个别IOS也可能是最大环回接口ip地址),若R9没有环回接口;FA地址为R9上最后宣告的物理接口地址(个别IOS也可能是最大的物理接口ip地址)

R9的S0/1也工作OSPF协议中,S0/1接口工作方式为广播,那么FA地址为R10接口ip;

S0/1的工作方式为点到点,那么FA地址为R9的s0/1口ip

切记:在FA地址出现后,4类LSA无效;人为过滤掉4类LSA,依然可达域外;

当4类LSA存在,却人为过滤了到达FA地址的路由,那么将无法访问域外;

一旦出现FA地址,所有的选路计算均基于FA地址进行;

注:1、针对存在FA的5/7类路由,4类LSA无意义,仅递归到FA地址;若FA地址被策略过滤导致不可 达;

2、路由表中的度量是到FA地址的度量,不是到ASBR的度量;

【4】NP位+E位

P位被加密,故抓包时看不见P位;

正常NSSA区域内的hello包中,N=1 E=0 标识该区域转发7类LSA,不转发5类;非NSSA区域E=1 N=0 标识可以转发5类,不能转发7类,P位为1,标识该区域将执行7类转5类; P为0,不能7转5;

若NSSA和非NSSA均将同一条域外路由向内部传递,仅非NSSA区域可以实现;

区域0连接到两个非骨干区域,这两个非骨干假设为区域1和区域2;区域1/2同时连接同一个外部协议,且同时进行了重发布配置;区域1为NSSA区域,区域2为非NSSA区域;那么此时的区域1,P位=0不能进行7转5;故骨干区域只能收到从区域2来的外部路由;

若区域1和区域2均为NSSA区域,那么ABR的RID大区域进行7转5,另一个区域不转,

故同一条域外路由,骨干区域只能收到从一个区域传递的外部路由;若以上条件中,两个区域均为非NSSA区域,那么P位无效,故两个区域的路由均回进入骨干区域;

【5】OSPF状态机

1、点到点网络类型

down -->init -- >(前提为可以建立邻接)exstart -->exchange-->若查看邻接的DBD目录后发现不用进行LSA直接进入full 若查看后需要进行查询、应答先进入loading,在查询应答完后再进入full;

2、MA网络类型

down -->init -- >2way-->(前提为可以建立邻接,通过DR/BDR选举后来判断)exstart -->exchange-->若查看邻接的DBD目录后发现不用进行LSA直接进入full 若查看后需要进行查询、应答先进入loading,在查询应答完后再进入full;

3、当hello time较大时,状态机在down和init之间将出现尝试等待状态;

【6】SFP算法 –OSPF防环机制

  1. 在同一个区域每台路由具有一致的LSDB

  1. 每台路由器以自己为根计算到达每个目标的最短路径(最小cost值)

  1. 必须区域划分--

优势-1)域间汇总减少路由条目数量

  1. 汇总路由是在所有明细路由均消失后才删除,网络更稳定

  1. 区域划分后不同类别的LSA传播范围不同,控制更新量

总结:观看OSPF防环文档

过程--基于本地LSDB(1/2类LSA)生成--生成有向图--基于有向图来进行最短路径树生成

最短路径树,关注本地LINK-ID的LSA开始--》基于该LSA内提及到点到点或传输网络信息再查看link-id递归到下一条信息;基于所有点到点和传输网络信息生成最短路径树主干;

然后用树中每台设备的末梢网络信息补充路由表,完成收敛;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值