RIP的防环机制
 
实验连接图
3.6 RIP的防环机制_RIP
提要描述
1-记数无穷大(maximum hop count):定义最大跳数(最大为15跳),当跳数为16跳时,目标为不可达。

2-水平分割split horizon:从一个接口学习到的路由不会再广播回该接口。cisco可以对每个接口关闭水平分割功能。这个特点在( N B M A )非广播多路访问hub-and-spoke 环境下十分有用。
 
3-毒性逆转poison reverse:从一个接口学习的路由会发送回该接口,但是已经被毒化,跳数设置为16跳,不可达。
 
4-触发更新trigger update一旦检测到路由崩溃立即广播路由刷新报文而不等到下一刷新周期
 
5-抑制计时器holddown timer):防止路由表频繁翻动,增加了网络的稳定性。
 
实验目标: 通过实验调试出各个现象
基本配置
R1的配置
R2的配置
!
hostname R1
!
interface Loopback0
 ip address 1.1.1.1 255.255.255.0
!
interface Serial1/0
 ip address 13.1.1.1 255.255.255.0
no shut
!
interface Serial1/1
 ip address 12.1.1.1 255.255.255.0
 no shut
!
router rip
 network 1.0.0.0
 network 12.0.0.0
 network 13.0.0.0
!
!
hostname R2
!
interface Serial1/0
 ip address 12.1.1.2 255.255.255.0
 no shut
!
interface Serial1/1
 ip address 23.1.1.2 255.255.255.0
 no shut
!
router rip
 network 12.0.0.0
 network 23.0.0.0
!
R3的配置
 
!
hostname R3
!
interface Serial1/0
 ip address 23.1.1.3 255.255.255.0
 no shut
!
interface Serial1/1
 ip address 13.1.1.3 255.255.255.0
 no shut
!
router rip
 network 13.0.0.0
 network 23.0.0.0
!
 
↓调试配置及监测步骤↓
 
注意!!请在完成每个分解实验的时候,重启路由器重新配置表格的基本配置,再进行调试。
 

() 记数无穷大,16跳情况

 
产生16跳的工作过程:
1:  R1丢失了looback接口的网络(下面简称网络A)后,产生一个即时更新送往R2R3。这个更新信息要告诉R2R3R1不再有到达网络A的路径。然而这个更新信息传输到R3被推迟了C P U忙、链路拥塞等),但到达了R2R2从路由表中去掉到网络A的路径。
 
2:  R3仍未收到R1的即时更新信息,并发出它的常规路由选择更新信息,通告网络A2跳的距离可达R2收到这个更新信息,认为出现了一条新路径到网络A
 
3:  R2告诉R1它能以3跳的距离到达网络A
 
4:  R1告诉R3它能以4跳的距离到达网络A
 
5:  这个循环将进行到跳数为无穷,在R I P中定义为1 6。一旦一个路由器达到无穷,它将声明这条路径不可用并从路由表中删除此路径。由于记数到无穷大问题,路由选择信息将从一个路由器传到另一个路由器,每次段数加一。路由选择环路问题将无限制地进行下去,除非达到某个限制。这个限制就是R I P的最大跳数。当路径的跳数超过1 5,这条路径就从路由表中删除。
 
 
操作步骤:
 
第一步:各个路由器完成基本配置,R2的路由表如下:
R2#sh ip route
R    1.0.0.0/8 [120/1] via 12.1.1.1, 00:00:01, Serial1/0
     23.0.0.0/24 is subnetted, 1 subnets
C       23.1.1.0 is directly connected, Serial1/1
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/0
R    13.0.0.0/8 [120/1] via 23.1.1.3, 00:00:23, Serial1/1
                [120/1] via 12.1.1.1, 00:00:01, Serial1/0
网络1.0.0.0是学自R1
 
第二步:被动R1s1/1接口,令R2学到网络A是来自R3,而不是R1
大约4分钟后,R2的路由表如下:
R1(config)#router rip
R1(config-router)#passive-interface s1/1
R2#show ip route
R    1.0.0.0/8 [120/2] via 23.1.1.3, 00:00:06, Serial1/1
     23.0.0.0/24 is subnetted, 1 subnets
C       23.1.1.0 is directly connected, Serial1/1
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/0
R    13.0.0.0/8 [120/1] via 23.1.1.3, 00:00:22, Serial1/1
现在R2学到1.0.0.0的网络是来自R3
 
第三步:R1s1/0的接口也被动掉,且断开lookback0接口。且打开个各个路由器的debug ip rip
 
R1(config)#router rip
R1(config-router)#passive-interface s1/0
 
R1(config)#int loopback 0
R1(config-if)#shutdown
 
第四步:直到R1收来1.0.0.0的网络是来自R2后,再取消R1被动s1/0接口。
 
R1#sh ip route
R    1.0.0.0/8 [120/3] via 12.1.1.2, 00:00:01, Serial1/1
R    23.0.0.0/8 [120/1] via 13.1.1.3, 00:00:19, Serial1/0
                [120/1] via 12.1.1.2, 00:00:01, Serial1/1
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/1
     13.0.0.0/24 is subnetted, 1 subnets
C       13.1.1.0 is directly connected, Serial1/0
R1现在的路由表学到的1.0.0.0网络是来自R2
 
R1(config)#router rip
R1(config-router)#no passive-interface s1/0
 
第五步:通过上面的一系列设置,1.0.0.0这个网络已经在拓扑上出现R1—R3—R2—R1这样的路由环。下面我们看看debug信息:
 
R3#debug ip rip
*Mar  9 00:49:27.839: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (23.1.1.3)  #----发送到R2
*Mar  9 00:49:27.839: RIP: build update entries
*Mar  9 00:49:27.843:   network 1.0.0.0 metric 2
*Mar  9 00:49:27.843:   network 13.0.0.0 metric 1
R3#
*Mar  9 00:49:39.335: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:49:39.339:      1.0.0.0 in 4 hops #----接收来自R14
*Mar  9 00:49:39.339:      12.0.0.0 in 1 hops
*Mar  9 00:49:41.343: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:49:41.343: RIP: build flash update entries
*Mar  9 00:49:41.347:   network 1.0.0.0 metric 5
R3#
*Mar  9 00:49:45.463: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:49:45.463:      1.0.0.0 in 7 hops
*Mar  9 00:49:47.463: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:49:47.463: RIP: build flash update entries
*Mar  9 00:49:47.463:   network 1.0.0.0 metric 8
R3#
*Mar  9 00:49:51.347: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:49:51.347:      1.0.0.0 in 10 hops
*Mar  9 00:49:53.355: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:49:53.355: RIP: build flash update entries
*Mar  9 00:49:53.359:   network 1.0.0.0 metric 11
*Mar  9 00:49:53.507: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:49:53.507: RIP: build update entries
*Mar  9 00:49:53.511:   network 1.0.0.0 metric 11
*Mar  9 00:49:53.511:   network 13.0.0.0 metric 1
R3#
*Mar  9 00:49:57.387: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:49:57.391:      1.0.0.0 in 13 hops
R3#
*Mar  9 00:49:59.395: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:49:59.395: RIP: build flash update entries
*Mar  9 00:49:59.399:   network 1.0.0.0 metric 14
R3#
*Mar  9 00:50:03.583: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:50:03.587:      1.0.0.0 in 16 hops (inaccessible)  #--跳数去到16,已经无限大,不可达了。于是R3马上向所有接口发送16跳不可达信息。↓↓
R3#
*Mar  9 00:50:05.587: RIP: sending v1 flash update to 255.255.255.255 via Serial1/1 (13.1.1.3)
*Mar  9 00:50:05.587: RIP: build flash update entries
*Mar  9 00:50:05.591:   network 1.0.0.0 metric 16
*Mar  9 00:50:05.591: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 00:50:05.595: RIP: build flash update entries
*Mar  9 00:50:05.595:   network 1.0.0.0 metric 16
R3#     --------------------同时R3也收到其他路由器发来不可达的信息------------
*Mar  9 00:50:07.603: RIP: received v1 update from 23.1.1.2 on Serial1/0
*Mar  9 00:50:07.607:      1.0.0.0 in 16 hops (inaccessible)
*Mar  9 00:50:07.863: RIP: received v1 update from 13.1.1.1 on Serial1/1
*Mar  9 00:50:07.867:      1.0.0.0 in 16 hops (inaccessible)
*Mar  9 00:50:07.867:      12.0.0.0 in 1 hops
 
 
 
 

() 水平分割

 
水平分割规则是:从一个接口学习到的路由不会再广播回该接口。
 
下面我们看看在串行链路中水平分割的情况。为了方便测试我们先断开R1s1/0接口
 
R1(config)#int s1/0
R1(config-if)#shutdown
 
看看R2R3的路由表
R2#sh ip route
R    1.0.0.0/8 [120/1] via 12.1.1.1, 00:00:17, Serial1/0
     23.0.0.0/24 is subnetted, 1 subnets
C       23.1.1.0 is directly connected, Serial1/1
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/0
可以看到R2学到了来自R11.0.0.0/8路由条目
 
R3#sh ip route
R    1.0.0.0/8 [120/2] via 23.1.1.2, 00:00:14, Serial1/0
     23.0.0.0/24 is subnetted, 1 subnets
C       23.1.1.0 is directly connected, Serial1/0
R    12.0.0.0/8 [120/1] via 23.1.1.2, 00:00:14, Serial1/0
可以看到R3通过R2学到了1.0.0.0/8路由条目
 
 
现在通过debug ip rip看看R2接收和发送情况。
 
R2#debug ip rip
RIP protocol debugging is on
*Mar  9 14:30:51.939: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 14:30:51.943:      1.0.0.0 in 1 hops  #---接收到来自R11跳的路由
R2#
*Mar  9 14:30:53.695: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (12.1.1.2)   #----发送到R1的更新
*Mar  9 14:30:53.695: RIP: build update entries
*Mar  9 14:30:53.699:   network 23.0.0.0 metric 1
R2#
*Mar  9 14:31:03.315: RIP: sending v1 update to 255.255.255.255 via Serial1/1 (23.1.1.2)   #----发送到R3的更新
*Mar  9 14:31:03.315: RIP: build update entries
*Mar  9 14:31:03.319:   network 1.0.0.0 metric 2
*Mar  9 14:31:03.319:   network 12.0.0.0 metric 1
debug信息可以看到,R2s1/0接收来自R11.0.0.0/8路由条目,再s1/0发送更新时,只有23.0.0.0的网络,并没有包括了1.0.0.0的网络,但s1/1发送R3的更新时,却包括了1.0.0.0的网络,这就是说水平分割已经起作用了。
 
现在我们来看看关闭水平分割的情况
 
R1(config)#int s1/1
R1(config-if)#no ip split-horizon
 
R2(config)#int s1/0
R2(config-if)#no ip split-horizon
 
 
R2# debug ip rip
 
*Mar  9 14:46:03.123: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 14:46:03.127:      1.0.0.0 in 1 hops
*Mar  9 14:46:03.127:      12.1.1.0 in 1 hops
*Mar  9 14:46:03.127:      23.0.0.0 in 2 hops
*Mar  9 14:46:03.651: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 14:46:03.651: RIP: build update entries
*Mar  9 14:46:03.655:   network 1.0.0.0 metric 2
*Mar  9 14:46:03.655:   subnet 12.1.1.0 metric 1
*Mar  9 14:46:03.655:   network 23.0.0.0 metric 1
debug信息可以看到,关闭水平分割之后,R2S1/0接收来自R11.0.0.0网络,又从S1/0发送回R1
 
现在我们来玩个小游戏,就是利用在R1R2关闭了水平分割只用两个路由器就能产生一跳一跳地增加16跳的效果,实验前都要打开R1R2debug ip rip来监测
 
1:先被动掉R1s1/1接口
R1(config)#router rip
R1(config-router)#passive-interface s1/1
 
2:关闭loopback0接口
R1(config)#int loopback 0
R1(config-if)#shutdown
*Mar  9 15:13:25.567: %LINK-5-CHANGED: Interface Loopback0, changed state to administratively down
 
3:取消R1S1/1接口的被动
R1(config-if)#
R1(config-router)#no passive-interface s1/1
 
4:R2为例看看它的debug ip rip信息
 
R2#debug ip rip
*Mar  9 15:13:54.551: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:13:54.551: RIP: build update entries
*Mar  9 15:13:54.555:   network 1.0.0.0 metric 2
*Mar  9 15:13:54.555:   subnet 12.1.1.0 metric 1
*Mar  9 15:13:54.555:   network 23.0.0.0 metric 1
R2#
*Mar  9 15:14:10.347: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:10.351:      1.0.0.0 in 3 hops
*Mar  9 15:14:10.351:      12.1.1.0 in 1 hops
*Mar  9 15:14:10.355:      23.0.0.0 in 2 hops
R2#
*Mar  9 15:14:12.351: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:12.351: RIP: build flash update entries
*Mar  9 15:14:12.355:   network 1.0.0.0 metric 4
R2#
*Mar  9 15:14:14.371: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:14.375:      1.0.0.0 in 5 hops
R2#
*Mar  9 15:14:16.375: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:16.375: RIP: build flash update entries
*Mar  9 15:14:16.379:   network 1.0.0.0 metric 6
R2#
*Mar  9 15:14:18.495: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:18.499:      1.0.0.0 in 7 hops
R2#
*Mar  9 15:14:20.499: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:20.499: RIP: build flash update entries
*Mar  9 15:14:20.503:   network 1.0.0.0 metric 8
R2#
*Mar  9 15:14:22.623: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:22.627:      1.0.0.0 in 9 hops
*Mar  9 15:14:22.763: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:22.763: RIP: build update entries
*Mar  9 15:14:22.767:   network 1.0.0.0 metric 10
*Mar  9 15:14:22.767:   subnet 12.1.1.0 metric 1
*Mar  9 15:14:22.767:   network 23.0.0.0 metric 1
R2#
*Mar  9 15:14:24.895: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:24.899:      1.0.0.0 in 11 hops
R2#
*Mar  9 15:14:26.899: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:26.899: RIP: build flash update entries
*Mar  9 15:14:26.903:   network 1.0.0.0 metric 12
R2#
*Mar  9 15:14:28.967: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:28.971:      1.0.0.0 in 13 hops
R2#
*Mar  9 15:14:30.971: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:30.971: RIP: build flash update entries
*Mar  9 15:14:30.975:   network 1.0.0.0 metric 14
R2#
*Mar  9 15:14:33.023: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:33.027:      1.0.0.0 in 15 hops
R2#
*Mar  9 15:14:35.027: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:35.027: RIP: build flash update entries
*Mar  9 15:14:35.027:   network 1.0.0.0 metric 16
R2#
*Mar  9 15:14:37.083: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 15:14:37.087:      1.0.0.0 in 16 hops (inaccessible)
R2#
*Mar  9 15:14:39.087: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 15:14:39.087: RIP: build flash update entries
*Mar  9 15:14:39.091:   network 1.0.0.0 metric 16
上面就是两路由器间关闭水平分割,产生16跳的效果了,为了直观中间我删除了部分debug信息。
 
其实原理很简单:
我们把R1S1/1出口passive 了,R1 就不能把lo 0shutdown掉的信息以flash update 的形式发给R2,同时我们也把R1R2的两接口的水平分割关了。
这时不知道情况的R2就发送更新对R1说:“你到lo 0是2跳”。而现在R1本身已经没有了与自身直连的lo 0的0跳信息,所以它别无选择的接受R2发来的2跳。
当我们取消R1S1/1被动功能,R1再对R2说:“你到lo 0是3跳”。虽然比原来的差,且是从同一个接口收到的,但R2它也别无选择。
就这样它们之间就相互“欺骗”,如此循环直到出现16跳。
 

() 毒性逆转

毒性逆转的规则是:从一个接口学习的路由会发送回该接口,但是已经被毒化,跳数设置为16跳,不可达。
 
 
实验步骤:
 
1:为了方便测试我们断开R1R3链接的S1/0接口
R1(config)#int s1/0    
R1(config-if)#shutdown
 
2:各个路由器全部路由都学到了,在各个路由器打开debug ip rip观察
 
3: 断开R1loopback0接口
R1(config)#int loopback 0
R1(config-if)#shutdown
 
R1#debug ip rip
*Mar  9 17:18:08.811: RIP: received v1 update from 12.1.1.2 on Serial1/1
*Mar  9 17:18:08.815:      1.0.0.0 in 16 hops (inaccessible)
*Mar  9 17:18:08.815:      23.0.0.0 in 1 hops
R1#
*Mar  9 17:18:12.807: RIP: sending v1 update to 255.255.255.255 via Serial1/1 (12.1.1.1)
*Mar  9 17:18:12.807: RIP: build update entries
*Mar  9 17:18:12.811:   network 1.0.0.0 metric 16
从接口S1/1收到,又出接口S1/1发出去,但已经标记为16跳不可达
 
R2#debug ip rip
*Mar  9 17:17:46.727: RIP: received v1 update from 12.1.1.1 on Serial1/0
*Mar  9 17:17:46.731:      1.0.0.0 in 16 hops (inaccessible)
R2#
*Mar  9 17:17:48.731: RIP: sending v1 flash update to 255.255.255.255 via Serial1/0 (12.1.1.2)
*Mar  9 17:17:48.731: RIP: build flash update entries
*Mar  9 17:17:48.735:   network 1.0.0.0 metric 16
 
*Mar  9 17:17:48.735: RIP: sending v1 flash update to 255.255.255.255 via Serial1/1 (23.1.1.2)
*Mar  9 17:17:48.739: RIP: build flash update entries
*Mar  9 17:17:48.739:   network 1.0.0.0 metric 16
R2#
*Mar  9 17:17:50.799: RIP: received v1 update from 23.1.1.3 on Serial1/1
*Mar  9 17:17:50.803:      1.0.0.0 in 16 hops (inaccessible)
从信息也已经看到从同一个接口收到,也在同一个接口发出,但也是已经毒化
 
R3#debug ip rip
*Mar  9 17:18:07.551: RIP: received v1 update from 23.1.1.2 on Serial1/0
*Mar  9 17:18:07.555:      1.0.0.0 in 16 hops (inaccessible)
*Mar  9 17:18:07.555:      12.0.0.0 in 1 hops
R3#
*Mar  9 17:18:20.955: RIP: sending v1 update to 255.255.255.255 via Serial1/0 (23.1.1.3)
*Mar  9 17:18:20.955: RIP: build update entries
*Mar  9 17:18:20.955:   network 1.0.0.0 metric 16
R3的情况也是一样,从相同的接口接收和发送。
 
注意!!:以上的效果是不用关闭水平分割的,否则不能说明毒性逆转
 

() 触发更新

触发更新的规则是一旦检测到路由崩溃立即广播路由刷新报文而不等到下一刷新周期
 
 
下面我们就以R1R2为例子做实验
 
1:完成基本配置,都学全路由后,我们在R1 打开debug ip ripdebug ip rip trigger
 
2: 先在R1S1/1启动触发更新(ip rip triggered
 
R1(config)#int s1/1
R1(config-if)#ip rip triggered
 
3:查看debug信息
R1#debug ip rip
RIP protocol debugging is on
R1#debug ip rip trigger
RIP trigger debugging is on
 
*Mar  9 18:26:55.963: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第一次请求
*Mar  9 18:26:55.963: RIP: Start poll timer from 12.1.1.1 on Serial1/1
*Mar  9 18:26:59.707: RIP-TIMER: sending timer on Serial1/1 expired
*Mar  9 18:26:59.999: RIP-TIMER: age timer expired
*Mar  9 18:27:00.247: RIP-TIMER: sending timer on Loopback0 expired
*Mar  9 18:27:00.963: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired  #----第一次超时
*Mar  9 18:27:00.963: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第二次请求
*Mar  9 18:27:00.967: RIP: Start poll timer from source 12.1.1.1 on Serial1/1
R1#
*Mar  9 18:27:05.967: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired  #----第二次超时
*Mar  9 18:27:05.967: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第三次请求
*Mar  9 18:27:05.967: RIP: Start poll timer from source 12.1.1.1 on Serial1/1
R1#
*Mar  9 18:27:09.999: RIP-TIMER: age timer expired
*Mar  9 18:27:10.967: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired  #----第三次超时
*Mar  9 18:27:10.967: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第四次请求
*Mar  9 18:27:10.971: RIP: Start poll timer from source 12.1.1.1 on Serial1/1
R1#
*Mar  9 18:27:15.971: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired  #----第四次超时
*Mar  9 18:27:15.971: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第五次请求
*Mar  9 18:27:15.975: RIP: Start poll timer from source 12.1.1.1 on Serial1/1
R1#
*Mar  9 18:27:19.999: RIP-TIMER: age timer expired
*Mar  9 18:27:20.975: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired  #----第五次超时
*Mar  9 18:27:20.975: RIP: sending triggered request on Serial1/1 to 255.255.255.255  #----第六次请求
*Mar  9 18:27:20.979: RIP: Start poll timer from source 12.1.1.1 on Serial1/1
R1#
*Mar  9 18:27:25.979: RIP-TIMER: polling timer on Serial1/1(12.1.1.1) expired
*Mar  9 18:27:25.979: RIP: Poll 6 times on Serial1/1 thru 12.1.1.1 without any ack   #----经过6次触发请求后还没有收到确认消息
R1#
*Mar  9 18:27:29.463: RIP-TIMER: sending timer on Serial1/1 expired 
*Mar  9 18:27:29.463: RIP: sending v1 update to 255.255.255.255 via Serial1/1 (12.1.1.1)  #---请求无效后,发送一个普通的广播更新
*Mar  9 18:27:29.467: RIP: build update entries
*Mar  9 18:27:29.467:   network 1.0.0.0 metric 1
*Mar  9 18:27:29.467:   network 13.0.0.0 metric 1
*Mar  9 18:27:29.999: RIP-TIMER: age timer expired
R1#
*Mar  9 18:27:32.895: RIP: received v1 update from 12.1.1.2 on Serial1/1
*Mar  9 18:27:32.899:      23.0.0.0 in 1 hops  #----还可以收到R2来的信息,是因为R2始终在广播着他自己的RIP更新
 
R1debug调试信息中,显示的就是R1启动了触发更新试图与链路的另一端的R2建立触发更新关系。R15s为每个周期发送轮询(Poll并等待确认,但发送了6触发请求后还没有收到确认消息,那么整个轮询过程就认为超时,触发更新建立不成功,路由器R1等待下一个普通的更新时间,并广播一个普通RIP的更新。而在整个过程R2始终在广播着他自己的RIP更新。
 
 
4: 我们现在在R2也打开debug ip ripdebug ip rip,并且把R2S1/1接口也启动触发更新(ip rip triggered)。
 
R2#debug ip rip
RIP protocol debugging is on
R2#debug ip rip trigger
RIP trigger debugging is on
R2(config)#int s1/0
R2(config-if)#ip rip triggered
*Mar  9 19:43:45.231: RIP: sending triggered request on Serial1/0 to 255.255.255.255  #----R2发送触发更新请求
*Mar  9 19:43:45.231: RIP: Start poll timer from 12.1.1.2 on Serial1/0
*Mar  9 19:43:45.347: RIP: received v1 triggered update from 12.1.1.1 on Serial1/0   #----S1/0收到来自R1的触发更新
*Mar  9 19:43:45.351: RIP: sending v1 ack to 12.1.1.1 via Serial1/0 (12.1.1.2), #----R2通过S1/0接口向R1发送确认信息
     flush, seq# 0
*Mar  9 19:43:45.355: RIP: Stop trigger rip poll timer for 12.1.1.2 on Serial1/0  #----停止向R1发送触发更新的轮询
*Mar  9 19:43:45.355: RIP: Trigger rip running on network 12.0.0.0 thru Serial1/0  #----透过S1/0接口在网络12.0.0.0上运行着RIP的触发更新
*Mar  9 19:43:45.359: RIP: 12.1.1.1 change state from DOWN to INIT
*Mar  9 19:43:45.359: RIP: send v1 triggered flush update to 12.1.1.1 on Serial1/0 with no route
*Mar  9 19:43:45.363: RIP: assigned sequence number 0 on Serial1/0
*Mar  9 19:43:45.363: RIP: start retransmit timer of 12.1.1.1
*Mar  9 19:43:45.363:      1.0.0.0 in 1 hops
*Mar  9 19:43:45.367:      13.0.0.0 in 1 hops
*Mar  9 19:43:45.443: RIP: received v1 triggered ack from 12.1.1.1 on Serial1/0
R2#
*Mar  9 19:43:45.447: RIP: 12.1.1.1 change state from INIT to LOADING
*Mar  9 19:43:45.447: RIP: send v1 triggered update to 12.1.1.1 on Serial1/0
*Mar  9 19:43:45.447: RIP: assigned sequence number 1 on Serial1/0
*Mar  9 19:43:45.451: RIP: build update entries
*Mar  9 19:43:45.451:   route 8: network 23.0.0.0 metric 1
*Mar  9 19:43:45.455: RIP: Update contains 1 routes, start 8, end 8
*Mar  9 19:43:45.455: RIP: start retransmit timer of 12.1.1.1
*Mar  9 19:43:45.463: RIP: received v1 triggered ack from 12.1.1.1 on Serial1/0
     seq# 1
*Mar  9 19:43:45.463: RIP: 12.1.1.1 change state from LOADING to FULL
*Mar  9 19:43:46.539: RIP-TIMER: age timer expired  #----计数器超时
R2#
*Mar  9 19:43:53.259: RIP-TIMER: sending timer on Serial1/1 expired
*Mar  9 19:43:53.259: RIP: sending v1 update to 255.255.255.255 via Serial1/1 (23.1.1.2)
*Mar  9 19:43:53.263: RIP: build update entries
*Mar  9 19:43:53.263:   network 1.0.0.0 metric 2
*Mar  9 19:43:53.263:   network 12.0.0.0 metric 1
R2#
*Mar  9 19:43:55.491: RIP: received v1 update from 23.1.1.3 on Serial1/1
*Mar  9 19:43:55.495:      1.0.0.0 in 2 hops
*Mar  9 19:43:55.495:      13.0.0.0 in 1 hops
R2#
*Mar  9 19:43:56.539: RIP-TIMER: age timer expired
R2#
*Mar  9 19:44:06.539: RIP-TIMER: age timer expired
*Mar  9 19:44:07.383: RIP-TIMER: sending timer on Serial1/0 expired
从上面的debug信息,可以看到,由请求轮询确认是很短的时间的。再就是触发状态从DOWN状态开始,经过INTLOADING状态,最后到为FULL状态。而后的就是进行路由信息的交换和更新确认了。而在输出信息的后面也出现了RIP更新计时器超时做实验时候花多些时间,细心观察debug信息,R2会一直没有向R1发送新的更新R1那里接收新的更新。这就是RIP启用触发更新会关闭计时器的效果。
 
 
下面再看看R1R2的路由表和RIP 数据库
 
R1#show ip route
     1.0.0.0/24 is subnetted, 1 subnets
C       1.1.1.0 is directly connected, Loopback0
R    23.0.0.0/8 [120/1] via 12.1.1.2, 00:10:05, Serial1/1
                [120/1] via 13.1.1.3, 00:00:03, Serial1/0
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/1
     13.0.0.0/24 is subnetted, 1 subnets
C       13.1.1.0 is directly connected, Serial1/0
 
R2#show ip route
R    1.0.0.0/8 [120/1] via 12.1.1.1, 00:10:40, Serial1/0
     23.0.0.0/24 is subnetted, 1 subnets
C       23.1.1.0 is directly connected, Serial1/1
     12.0.0.0/24 is subnetted, 1 subnets
C       12.1.1.0 is directly connected, Serial1/0
R    13.0.0.0/8 [120/1] via 12.1.1.1, 00:39:40, Serial1/0
                [120/1] via 23.1.1.3, 00:00:14, Serial1/1
 
R1#show ip rip database
1.0.0.0/8    auto-summary
1.1.1.0/24    directly connected, Loopback0
12.0.0.0/8    auto-summary
12.1.1.0/24    directly connected, Serial1/1
13.0.0.0/8    auto-summary
13.1.1.0/24    directly connected, Serial1/0
23.0.0.0/8    auto-summary
23.0.0.0/8
    [1] via 13.1.1.3, 00:00:06, Serial1/0
    [1] via 12.1.1.2, 00:10:22 (permanent), Serial1/1
   * Triggered Routes:
     - [1] via 12.1.1.2, Serial1/1
 
 
R2#show ip rip database
1.0.0.0/8    auto-summary
1.0.0.0/8
    [1] via 12.1.1.1, 00:11:14 (permanent), Serial1/0
   * Triggered Routes:
     - [1] via 12.1.1.1, Serial1/0
12.0.0.0/8    auto-summary
12.1.1.0/24    directly connected, Serial1/0
13.0.0.0/8    auto-summary
13.0.0.0/8
    [1] via 23.1.1.3, 00:00:02, Serial1/1
    [1] via 12.1.1.1, 00:11:14 (permanent), Serial1/0
   * Triggered Routes:
     - [1] via 12.1.1.1, Serial1/0
23.0.0.0/8    auto-summary
23.1.1.0/24    directly connected, Serial1/1
从上面的信息我们已经看到,路由表阴影部分的路由条目时间已经变得很大了,这是因为启动了触发更新学到的条目是永久permanent)的,在R1R2RIP数据库也已经证明了。
 
 

() 抑制计时器

请看以前的实验(RIP的定时器情况)
[url]http://sharkii.blog.51cto.com/325987/64146[/url]