EIGRP 是一种高级距离矢量型协议,从IGRP派生而来,兼有矢量型协议和链路状态型协议特点.汇聚快速,占用网络带宽少(数据流以多播或者单播的方式发送),无类路由支持VLSM,支持在任意节点上进行手工汇总,但默认开启自动汇总(可手工关闭).支持各种网络层协议,支持各种网络拓扑结构,100%保证无环路.它不发送完整更新,只在需要的时候发送部分更新.与IGRP兼容(度量是IGRP度量的256倍).它支持度量值不等的负载均衡(不同与IGRP).
使用的度量: 带宽K1 负载K2 延迟K3 可靠性K4 最大传输单元K5,默认情况下只有K1=K3=1 其他K值为0,所以默认情况下考虑带宽和延迟.
EIGRP的表:1邻居表,此表保存了所有邻居信息,确保直连邻居之间能够正常通信.为每种协议保存一个邻居表.
2.拓扑表,该表保存了所有从邻居路由器获得所有路由信息,包括正确的不正确的.通过该表,EIGRP能否了解网络拓扑结构.为每种协议保存一个拓扑表.
3.路由表,从拓扑表里选择一条最佳路由信息放到路由表里.为每种协议保存一个路由表.
后继路由保存在路由表里,也是当前正在用的路由.可行后继路由保存在拓扑表,它是当前路由的备份,可以为多条.
EIGRP的分组类型(5种):hello 更新 查询 应答 确认
hello:以多波发送,无需确认,用于维持邻居状态,洞悉邻居是否死亡等,根据链路速度不同 T1线路以下速率的每60秒发送一次,大于T1的每5秒一次.保持时间是hello时间的3倍,超过保持时间,路由器将认为邻居死亡,将从本地拓扑表里删除通过该邻居获得的所有路由.
更新update分组:包含拓扑更新,路由更新等正式数据流分组.通过多播发送,使用cisco的可靠传输协议RTP来发送更新,每个更新均需要确认,这导致了一个缺陷,当有多个路由确认较慢时,将导致整个网络路由器都陪伴等待,因为不获得确认,路由器不会发送下一个更新,解决方法是:通过RTP机制,当有路由器确认很慢时候,它将用单播方式与慢速路由器单独沟通发送更新.从而不影响其他路由器接收多波更新..多播流(multicast flow)定时器指定了从多播切换到单播之前所要等待的时间,RTO指定了发送2个连续单播之间的等待时间.EIGRP根据SRTT平均往返时间来计算RTO和多播流定时器.
查询分组:当路由器没有后继路由也没有可行后继路由时,EIGRP通过查询分组向所有邻居发送查询信息,以获得前往目标网络的新路由.查询需要确认.多波方式发送.
应答分组:对查询分组的应答,需要确认,以单播方式进行可靠的发送.
确认分组:用于对查询 更新 应答的确认,本身不需要确认.单播方式发送.
DUAL:一种扩散更新算法,用于EIGRP选择路由表和拓扑表.
FD:可行距离,就是自己到目标网络的度量值.在拓扑表里有该字段.
AD:通告距离,就是邻居到目标网络的度量值.在拓扑表里有该字段.
FD=当前路由器到下一跳邻居路由器的度量+AD
所以正常的路由条目必然是FD>AD
AD<FD是路由成为FS(feasiable successor)的前提条件
EIGRP将FD最小的路由确认为后继路由,并将与之相关的邻居路由器加入路由表里,EIGRP只依赖于下一跳路由器来发送数据.
FS 可行后继路由的选择,在将FD最小的作为后继路由后,EIGRP选择一个AD小于当前的FD(已成为后记路由的不算在内),作为FS.
EIGRP 默认路由:
当使用IP DEFAULT-NETWORK 网络号 这个命令设置了默认路由后,要向其他运行EIGRP的路由器也能学习到该默认路由,那么就必须使用network命令来宣告默认网络,也就是说让这个默认网络参与EIGRP进程.
待解答问题:如果使用IP ROUTE 0.0.0.0 0.0.0.0 接口或ip route 0.0.0.0 0.0.0.0 下一跳路由器接口地址 这个默认路由命令的话,是否要宣告或者是否能被其他路由器认识??还有一问题:一般我们尽量不将连接到internet的接口网络宣告进EIGRP进程,可是默认路由又需要,不是有点矛盾麽?
文章评论
如果使用IP ROUTE 0.0.0.0 0.0.0.0 接口或ip route 0.0.0.0 0.0.0.0 下一跳路由器接口地址 这个默认路由命令的话,是否要宣告或者是否能被其他路由器认识?
=》只能配置接口,不能配置为下一跳IP,不然其他路由器不认识
学习一下...