来简单描述一下常用的LSA
类型代码 描述
1 路由器lsa(本身接口ip,基本adv邻居接口状态)
2 网络lsa(p2p.p2m没有此类型.由DR产生.公告网络topo结构.只在广播网络中使用)
以上2条可使用sh ip os data network 查看
3 网络汇总lsa描述非backbone区域.由ABR产生
4 ASBR汇总lsa 描述到达ASBR的路经. 由ABR产生
以上2条可使用 sh ip os data summary 查看
5 外部的lsa(非ospf的条目,如rip.eigrp.static.分发进来)
可使用 sh ip os data external 查看
7 nssa外部lsa
可使用 sh ip os data nssa-external 查看
11 opaque lsa(AS范围)表示tag用
区 域 命 令
Area area-id stub ABR和这个区域内的所有路由器都要被配置
配置stub区域
存在lsa 1 2 3
backbone只向其通告缺省路由和域间路由
Area area-id stub no-summary 只在ABR上配置,这个区域内的路由器仍然配置为stub
配置一个完全的stub区域
存在lsa 1 2 以及一条OIA的缺省路由
backbone只向其通告缺省路由
Area area-id nssa ABR和这个区域内的所有路由器都要被配置
配置一个nssa区域
存在lsa 1 2 3 7
但由于这个区域中存在了ASBR.自然就产生了lsa5的外部路由.而stub区域本身不能存在这个类型的lsa. 于是nssa区域把本来stub中不允许存在的lsa5变为lsa7.所以nssa比stub多了一个lsa7.在这个lsa7到达nssa的ABR后,lsa7再变为lsa5向backbone进行通告
Area area-id nssa no-summary 只在ABR上配置,这个区域内的路由器仍然配置为nssa
配置一个完全的nssa区域
存在lsa 1 2 7
完全的nssa区域仍然把本身的N2(lsa7)条目在ABR上转为E2(lsa5)通告到backbone
Area area-id nssa no-redistribution
阻止redistribute的路由进入nssa区域
本来你配置nssa是因为你的区域中有一个和eigrp网路相连接的路由器.这时候你ASBR又宣告了一个rip的网络.backbone可以学习到,但对于nssa区域来说就没有必要了.这时候你可以使用它来阻止重分发的rip进入你的nssa区域.
仅用在ASBR上
Area area-id nssa default-infromation-originate
把一个缺省路由广播到nssa区域中
和stub区域会通告一条到达backbone的缺省路由(O*IA)不.nssa则不会自动产生
使用后不需要配置ip route .nssa就可以产生一条到达backbone的缺省路由(0*N2)
仅在ABR或ASBR上使用
Area area-id default-cost cost
设置stub区域的缺省成本 默认为1
在你的stub区域的某台路由器rack05R4上看到的O*IA的metric为65(64+1).然后你再ABR上设置cost为15.那么在返回rack05R4会看到metric为79(64+15).
仅在stub区域ABR上工作
汇聚内部路由 ( ABR 上使用 )
Area area-id range ip-add mask
Area area-id range ip-add mask advertise
这2个命令用途是一致的这儿就放在一起说明
比如你的area1中有
156.26.32.0/28 156.26.32.16/28 156.26.32.32/28 156.26.32.48/28
4个网段.你可以用area 1 range 156.26.32.0 255.255.255.192汇聚他们
这样在area0中看到的就是O IA 156.26.32.16/26一条路由而不是4条
同样你也可以从backbone(area0)向非backbone(area1)区域汇总
为了防止环路(通常在配置了缺省路由的情况下会发生)在某个被汇聚网段消失时,丢弃到这个网段的流量.建议使用ip route 156.26.32.0 255.255.255.192 null 0
Area area-id range ip-add mask not-advertise
抑制ABR广播的路由汇聚
汇聚外部路由 (可在ASBR和ABR上使用,但在ABR上使用时只能汇聚外部ospf路由)
Summary-address ip-add mask
比如你redistribute connected sbunets
156.26.32.0/28 156.26.32.16/28 156.26.32.32/28 156.26.32.48/28
4个网段.你可以用summary-address 156.26.32.0 255.255.255.192汇聚他们
这样在ospf的backbone中看到的就是O E2 156.26.32.16/26一条路由而不是4条
summary与range的区别
summary汇聚的是rip. eigrp. static重分发的路由.
Range汇聚的是ospf区域之间的路由
Summary-address ip-add mask not-advertise
阻止汇聚路由被ABR或ASBR广播
2 3 4
Summary-address ip-add mask tag value
在使用标记的网络中,允许给予标记值得路由策略,并且可以代替基于IP地址的路由策略
不说了,有点复杂,要配图和例子.我会做个试验说明的
Auto-cost reference-bandwidth bandwidth
全局性修改ospf各接口的成本
ospf把接口带宽分为10^8莱计算接口成本.当接口带宽大于100Mbit/s,不推荐使用缺省值(因为ospf不能区分大于100Mbit/s的接口)这是个全局性的.对于个别接口可以在接口下使用ip os cost (但不推荐)
接口类型 接口带宽 ospf成本
loopback 8 000 000 000 1
serial 56 000 1785
T1 1 544 000 64
Ethernet 10 000 000 10
fast Ethernet 100 000 000 1
Gigabit Ethernet 1 000 000 000 1
OC48 2 500 000 000 1
在同一区域中,所有的ospf路由器要配置相同的参考带宽(不同区域的参考带宽可以不同).
loopback的成本始终为1
产生缺省路由
Default-information originate
广播缺省路由到OSPF域内
如果1个ospf区域area0中有3台路由器rack05r1~r3.
而rack05r1成为了ASBR(比如连接到ISP)
那么只有rack05r1知道如何到达isp而r2和r3是不知道的
这时就需要在r1上使用Default-information originate来向r2和r3宣告如何到达
并且在r1上配置ip route 0.0.0.0 0.0.0.0 next hop
这样r2和r3会看到一条O*E2 0.0.0.0/0的缺省路由
Default-information originate always
无条件的广播缺省路由到OSPF域内
引用上面的说明.在r1上不配置ip route 0.0.0.0 0.0.0.0 next hop
r2和r3同样也会看到一条O*E2 0.0.0.0/0的缺省路由
always就是强制产生的意思
Default-information originate metric cost
Default-information originate always metric cost
如果不只一个OSPF路由器广播缺省路由.使用cost值可以用来选择最优路经.metric值越低(cost越低)越优先
Default-information originate metric-type type
Default-information originate always metric-type type
type的值有1和2两个等同于你在Default-information originate说明中R2和R3看到的是 O*E1 0.0.0.0/0还是O*E2 0.0.0.0/0
默认的是O*E2它的metric为1 不计算内部成本
也就是说你在r2和r3看到的关于O*E2 0.0.0.0/0 [110/1] 的metric为1
如果改为type1 那么你在r2和r3上看到的关于O*E1 0.0.0.0/0 [110/xxx] 那就不一定了.因为要计算内部路由的metric
Default-information originate route-map route-map-name
使用route-map有条件的广播缺省路由
如果使用了Default-information originate always 那么route-map将失效
也不好解释,我已经做好了配置演示,可以在论坛的NA版找到[ospf试验]产生缺省路由
Default-metric cost
为再分布的协议设置缺省的度量
比如在1个ospf域内有rack05r1和r2.
r1现在成为ASBR连接并重分发了一个eigrp的网络.
比如我们在r1上看到的eigrp的路由为D 3.3.3.3 [90/4046000]
那么r2上会看到0 E2 3.3.3.3 [110/20]
这时在r1上使用default-metric 55 之后r1上是不会有什么变化的
但r2上会看到0 E2 3.3.3.3 [110/55]
Distance administrative-distance
调整管理距离来影响路由的选路
1台路由器从2个以上的协议(ospf和rip)学习到同一个网络.这个时候AD就来选择最优路经.AD值低的优先选择
常见的AD
connected 0
static 1
ebgp 20
eigrp 90
igrp 100
ospf 110
is-is 115
rip 120
ibgp 200
例如1台路由器从eigrp和ospf都学到一条3.3.3.3的路由
正常情况下sh ip route出来的是D 3.3.3.3 [90/xxx] (eigrp的AD为90<ospf的110)
但在这台路由器的ospf的进程下使用distance 80
那么再次sh ip router 则出来的是 O 3.3.3.3 [80/xxx] (现在ospf的110变为80<eigrp)
Distance administrative-distance source-ip-add source-ip-mask
更改从IP地址/mask相匹配的的原地址学习到的路由的AD
Distance administrative-distance source-ip-add source-ip-mask acl-num
更改使用acl选定的从IP地址/mask相匹配的的原地址学习到的路由的AD
Distance ospf external/inter-area/intra-area administrative-distance
用分布列表过滤路由
Distribute-list alc in
阻止从ospf学到的路由被放置到ip路由选择表中
在一个由rack05r1,r2和r3的路由器组成的ospf域中.
r1宣告了1.1.1.1 2.2.2.2 3.3.3.3 三个网段
在r2上定义1个acl
acc 1 deny 2.2.2.2 0.0.0.255
acc 1 deny 3.3.3.3 0.0.0.255
acc 1 permit any
然后在r2的ospf进程下使用 distribute-list 1 in
这样r2只能看到1.1.1.1的路由.
但是被过滤的路由条目仍然在r2的DB中存在 r3还是可以学习到所有的路由条目
ospf只能做in方向的过滤.out方向的过滤是无效的
Distribute-list acl in interface-type interface-number
阻止通过ospf特定接口学到的路由被放置到ip路由选择表中
Distribute-list alc out
Distribute-list acl out interface-type interface-number
以上2条命令对于DV协议如rip eigrp,阻止被acl选定的路由广播到邻居处
ospf是LS协议,路由是通过LSA传播的,因此这2条命令和ospf一起使用是无效的
Distribute-list acl out routing-process
阻止在分布到ospf的路由被放置到ip路由选择表中
在一个由rack05r1,r2和r3的路由器组成的ospf域中.
r1是一个ASBR学习到由eigrp 100网络宣告的路由D 3.3.3.3 和D 4.4.4.4
这样在r2和r3中会看到 O E2 3.3.3.3和 O E2 4.4.4.4
那么在r1中定义acl acc 1 permit 4.4.4.0 0.0.0.255
然后再ospf进程中使用 distribute-list out eigrp 100
这样r2和r3中只能看到 O E2 4.4.4.4 同时他们的DB中也不存在3.3.3.3
Distribute-list prefic prefix-list-name in
阻止从ospf学到的路由被放置到ip路由选择表中
其实就是用前缀列表代替acl. 引用Distribute-list alc in 的topo结构
ip prefix-list filter-ospf seq deny 2.2.2.2/32
ip prefix-list filter-ospf seq deny 3.3.3.3/32
ip prefix-list filter-ospf seq deny permit 0.0.0.0/0
在ospf进程中 distribute-list prefix filter-ospf in
我们可以看到同样的效果
Distribute-list prefic prefix-list-name in interface-type interface-number
阻止通过ospf特定接口学到的路由被放置到ip路由选择表中
Distribute-list prefic prefix-list-name out
Distribute-list prefic prefix-list-name out interface-type interface-number
以上2条命令对于DV协议如rip eigrp,阻止被acl选定的路由广播到邻居处
ospf是LS协议,路由是通过LSA传播的,因此这2条命令和ospf一起使用同样是无效的
Distribute-list prefic prefix-list-name out routing-process
阻止在分布到ospf的路由被放置到ip路由选择表中
引用Distribute-list acl out routing-process 的例子
更改配置 ip prefix-list filter-eigrp seq 5 permit 4.4.4.0/24
在ospf进程中 distri prefix filter-eigrp out eigrp 100
效果是一样的
记录OSPF邻居状态的改变
Log-adjacency-changes
把ospf的邻居状态改变信息记录到控制台
Log-adjacency-changes detail
把ospf的邻居状态改变信息记录到内存中
通过 show logging 显示缓冲区的内容
最大路经配置
Maximum-paths number-of-paths
在负载均衡的情况下,允许使用几条链路.默认4条.可以配置为1-6条
被动接口
Passive-interface interface-name interface-number
使用被动接口减少协议流量
如果s0/0,s0/1和e0/0三个接口都被network包含了,而e0/0没有任何ospf邻居.
就可以使用passive-interface e0/0 在指定接口阻止ospf包
Passive-interface default
如果你有100个接口被network包含,而只有s0/1一个接口有ospf邻接.
那么这条命令用起来就很爽了
passive-interface default
no passive-interface s0/1
其实我觉得network x.x.x.x 0.0.0.0 area x 更方便起码只用敲1行就好了
路由的再次分布
Redistribute routing-process process-id
使用缺省类型和度量把主类路由再次分发到ospf中
比如你的ASBR路由器分发了eigrp的
5.5.5.5./8 145.5.5.5/16 205.5.5.5/24 classful
6.5.5.5/12 146.5.5.5./18 206.5.5.5/28 classless
那么你的ASBR只能往其他的ospf路由器宣告
5.0.0.0/8 145.5.0.0/16 205.5.5.0/24
Redistribute routing-process process-id subnets
为了让上面所有的6个条目都能被正确宣告,加上subnets就ok了
Redistribute routing-process process-id metric ospf-metric
指定再分配的路由度量或成本
默认BGP缺省度量为1 其他的协议为20 取值0~16 777 214
Redistribute routing-process process-id metric-type ospf-metric
指定再分配的路由类型
缺省为2 取值1, 2
1 O*E1 计算内部成本
2 O*E2 不计算内部成本
Redistribute routing-process process-id tag tag-value
指定再分配的路由标记
附加到再分布路由的一个32位值.ospf本身没有使用路由标记,但可以在用于指定策略的route-map中引用(就是通过下面的命令实现),比如以tag为基础制定策略再次分布路由
缺省值为0 取值范围0~4 294 967 295
以上参数可以组合使用以满足特定需求
Redistribute routing-process process-id route-map route-map-name
基于tag来控制路由的再分配
比较繁琐,用法也比较多,配合上面的参数我会做个试验给大家看看的
ospf的命令很多比较多.比如接口配置的命令.没有在这里列举出来的原因
部分是要和其他的命名配合使用比如authentication. network. priority需和区域命令配合使用,再罗列出来会显得比较罗嗦.
还有些特性命令 demand-circuit. database-filter all out. fold-reduction和特殊环境下使用的 mtu-ignore .等等,
如果需要的话可以查阅 <Cisco OSPF Command and Configuration Handbook>