看看遞歸路由

拓撲:


203358805.png

屏幕剪輯的捕獲時間:2013/10/20 20:05

路由的遞歸查詢到底是幹什麼的?

路由的遞歸查詢針對靜態路由來講,對於動態路由就沒必要了。之所以要使用遞歸路由,目的是繞開那些經常變動的鏈路,可以使靜態路由的配置工作量減小。

使用遞歸路由的一個條件:到達目標網絡的鏈路在途中可以匯聚成比目標網絡數量更少的鏈路。

路由器逐跳將數據包發送到目的地,靜態路由可以指定到目的地的每一跳,但是如果路徑上某個節點出現問題,整條靜態路由就不能工作了,如果真的能用到靜態路由,則需要管理員重新指定一條可以到達目的地的靜態路由,很蛋疼。

遞歸路由可以在一定程度上解決這個問題:

對於上面的拓撲,R1需要經過R2R3路由器,將數據包發送給R4下的網段,管理員需要指定一條從R2R3R4下網段的靜態路由,如果指定的是經過R2的靜態路由,那如果R2不幸down掉,則需要在指定經過R3的路由,對於這樣簡單的拓撲還可以,但對於大點的網絡環境,則比較麻煩。

如果R1不指定R2R3,直接指定R4路由器的f0/0接口,如果R2 down掉,則可以通過R3繼續工作。


目標:

R1可以訪問R4路由之下的四個網段。

實現:

1.靜態路由關聯R2R3,來實現與R4的通信,但這樣存在問題,如果R2R3中有路由器無法使用了,得重新修改路由配置

2.直接關聯R4f0/0接口:這樣R2R3失效後,R1仍可以訪問R4網段,這裏用到就是遞歸路由了吧。

具體操作:

R1指定到R4的靜態路由:

R1(config)#ip route 40.0.1.0 255.255.255.0 fastEthernet0/020.2.2.4

R1(config)#ip route 40.1.1.0 255.255.255.0fastEthernet 0/020.2.2.4

R1(config)#ip route 40.2.1.0 255.255.255.0fastEthernet 0/020.2.2.4

R1(config)#ip route 40.3.1.0 255.255.255.0fastEthernet 0/020.2.2.4


R2指定到R4的靜態路由:

R2(config)#ip route 40.0.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R2(config)#ip route 40.1.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R2(config)#ip route 40.2.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R2(config)#ip route 40.3.1.0 255.255.255.0 fastEthernet 0/120.2.2.4


R3指定到R4的靜態路由:

R3(config)#ip route 40.0.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R3(config)#ip route 40.1.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R3(config)#ip route 40.2.1.0 255.255.255.0 fastEthernet 0/120.2.2.4

R3(config)#ip route 40.3.1.0 255.255.255.0 fastEthernet 0/120.2.2.4


R1要把報文發給40.0.1.0等四個網段,先要把報文發給靜態路由中指定的下一跳地址,也就是20.2.2.4,但R1的路由表裏沒有20.2.2.4的的路由條目,R1會幹什麼?R1會像PC一樣,發送ARP請求,用debug 來查看ARP信息:


Mar  1 00:25:23.783: IPARP: creating incomplete entry for IP address: 20.2.2.4 interfaceFastEthernet0/0

*Mar  1 00:25:23.783: IPARP: sent req src 10.1.1.1 c400.1910.0000,

                dst20.2.2.4 0000.0000.0000 FastEthernet0/0

這裏可以看到,R1發送arp請求,源地址是10.1.1.1,源mac地址是c400.1910.0000,目的地是:20.2.2.4,目的mac是:0000.0000.0000,通過接口:FastEthernet0/0,R1R2R3發送ARP請求,R2R3的代理ARP功能,會判斷,請求者和被請求者是不是在同一個廣播域,是否擁有去往源和目的地址的路由,是否開啓接口代理ARP,如果全部滿足,則R2R3就會給R1發送ARP應答。

R2中:

*Mar  1 00:25:21.859: IPARP: rcvd req src 10.1.1.1 c400.1910.0000, dst 20.2.2.4 FastEthernet0/0

*Mar  1 00:25:21.863: IPARP: sent rep src 20.2.2.4 c401.1910.0000,

                dst10.1.1.1 c400.1910.0000 FastEthernet0/0


R3

*Mar  1 00:48:20.815: IPARP: rcvd req src 10.1.1.1 c400.1910.0000, dst 20.2.2.4 FastEthernet0/0

*Mar  1 00:48:20.819: IPARP: sent rep src 20.2.2.4 c402.1910.0000,

                dst10.1.1.1 c400.1910.0000 FastEthernet0/0


來查看R1收到ARP應答的情況:

*Mar  1 00:49:24.239: IPARP throttled out the ARP Request for 20.2.2.4

*Mar  1 00:49:24.303: IPARP rep filteredsrc 20.2.2.4 c401.1910.0000, dst 10.1.1.1 c400.1910.0000 wrong cable, interfaceFastEthernet0/0

*Mar  1 00:49:24.303: IPARP rep filtered src 20.2.2.4 c402.1910.0000, dst 10.1.1.1 c400.1910.0000 wrongcable, interface FastEthernet0/0


這裏,發現R1將應答過濾掉了。。。


對於PC,如果該設備收到路由器傳遞的ProxyARP Reply,則該PC會信任該Reply,並將其加入ARP表中;

而對於路由器,如果該設備收到Proxy ARPReply,則該路由器會優先判斷該Reply中應答者ip地址所在網段是否可達,如果是,則接收,否則,直接丟棄。


這裏R1收到的ARP,應答者的ip地址應該是20.2.2.4,所以,R1會將收到的rep過濾掉。


可以在R1上添加一條去往20.2.2.0的路由條目

R1(config )#ip route 20.2.2.0 255.255.255.0 10.1.1.2

這一條靜態路由的作用就是,R1不過濾收到的代理ARP回覆,這裏的下一跳地址沒有實際意義。

R4上指定一個去R1的路由條目:

R4(config)#ip route 10.1.1.0 255.255.255.0 20.2.2.2


這樣R1就可以去往R4下網段了。


總結自閆輝-CCNP視頻


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章