两个人的电影免费视频_国产精品久久久久久久久成人_97视频在线观看播放_久久这里只有精品777_亚洲熟女少妇二三区_4438x8成人网亚洲av_内谢国产内射夫妻免费视频_人妻精品久久久久中国字幕

冗余轉(zhuǎn)發(fā)引擎的最優(yōu)化切換的方法和系統(tǒng)的制作方法

文檔序號(hào):7604485閱讀:213來(lái)源:國(guó)知局
專利名稱:冗余轉(zhuǎn)發(fā)引擎的最優(yōu)化切換的方法和系統(tǒng)的制作方法
技術(shù)領(lǐng)域
本發(fā)明涉及數(shù)據(jù)通信,更具體地說(shuō),涉及用于改進(jìn)網(wǎng)絡(luò)元件中的故障恢復(fù)的方法和系統(tǒng)。
背景技術(shù)
當(dāng)今,在網(wǎng)絡(luò)上傳輸?shù)男畔⒃絹?lái)越多,商家在向其顧客提供及時(shí)的服務(wù)和信息時(shí),已經(jīng)變得嚴(yán)重依賴其網(wǎng)絡(luò)基礎(chǔ)結(jié)構(gòu)。這種網(wǎng)絡(luò)基礎(chǔ)結(jié)構(gòu)中的故障在收入損失和雇員閑散方面都是代價(jià)高昂的。因而,高可靠性系統(tǒng)對(duì)連網(wǎng)設(shè)備的用戶來(lái)說(shuō)越來(lái)越具有吸引力。
此外,需要路由器、交換機(jī)以及其他的這類網(wǎng)絡(luò)元件在如此高的可靠性下提供不斷增長(zhǎng)的分組處理速率,而同時(shí)又要保持緊湊封裝,通常這就會(huì)要求使用在非常高的頻率工作的高度專用的ASIC(專用集成電路),因此這會(huì)散發(fā)出大量的熱量。這些考慮還會(huì)使設(shè)計(jì)適當(dāng)?shù)臋C(jī)架的問(wèn)題復(fù)雜化。當(dāng)在上述需求中加入對(duì)高可用性(冗余)的需求時(shí),問(wèn)題變得更加復(fù)雜。
交換機(jī)體系結(jié)構(gòu)的一個(gè)示例提供了服務(wù)于不同類型的物理接口的端口卡(port card),這些端口卡將它們的流量提供到轉(zhuǎn)發(fā)引擎。這些轉(zhuǎn)發(fā)引擎支持使用專用硬件的分布式轉(zhuǎn)發(fā)形式,其中專用硬件通常使用一個(gè)或多個(gè)ASIC。這些轉(zhuǎn)發(fā)引擎通過(guò)交換結(jié)構(gòu)(switching fabric)互連。通常還提供路由處理器(或者為了冗余目的,提供多個(gè)路由處理器),來(lái)管理異常處理以及轉(zhuǎn)發(fā)引擎不能管理的其他任務(wù)。
端口卡與轉(zhuǎn)發(fā)引擎卡分離,這允許使用相同的轉(zhuǎn)發(fā)引擎基礎(chǔ)結(jié)構(gòu)來(lái)容納多種通信技術(shù)。通過(guò)設(shè)計(jì)這樣的網(wǎng)絡(luò)元件,使該網(wǎng)絡(luò)元件的端口卡與轉(zhuǎn)發(fā)引擎功能性分離,從而在使用相同的基本轉(zhuǎn)發(fā)引擎體系結(jié)構(gòu)同時(shí),可以通過(guò)使用變化的端口卡體系結(jié)構(gòu)來(lái)支持這樣的多種通信技術(shù)(例如,協(xié)議、硬件接口等)。因此,這有利于避免為了支持不同線路接口而需要使用多種版本的轉(zhuǎn)發(fā)引擎。但是,在考慮冗余問(wèn)題時(shí),這種方法在處理向端口卡提供轉(zhuǎn)發(fā)功能的轉(zhuǎn)發(fā)引擎的故障時(shí)存在別的問(wèn)題。
但是,必須在冗余與對(duì)這些設(shè)計(jì)的物理及商業(yè)限制之間達(dá)到平衡。正如所指出的那樣,雖然希望獲得高可用性,但是必須在這種可用性與這種設(shè)計(jì)的成本以及物理尺寸和必須散發(fā)的熱能之間取得平衡。因?yàn)樵诮o定的體系結(jié)構(gòu)中加入了冗余元件,所以該體系結(jié)構(gòu)的可用性(可靠性)增加,但是由此其成本也上升,其尺寸和所產(chǎn)生的熱能也增大。因而,冗余的數(shù)量應(yīng)該被最小化,同時(shí)還提供必需的可用性水平。
可以從網(wǎng)絡(luò)元件的可用性與故障的影響及響應(yīng)于故障所執(zhí)行的恢復(fù)兩方面來(lái)看待這種可靠性。正如所指出的那樣,這種系統(tǒng)應(yīng)該在給定條件下提供可靠的服務(wù)。在發(fā)生故障時(shí),這種系統(tǒng)也應(yīng)該最大可能地(或者,至少應(yīng)該是商業(yè)上可接受的程度)提供服務(wù)的連續(xù)性。具體地,這意味著如果發(fā)生故障,則網(wǎng)絡(luò)元件所傳輸?shù)臄?shù)據(jù)流如果確實(shí)經(jīng)歷了中斷的話,那么應(yīng)該經(jīng)歷最小的中斷。
從前面的描述中可以清楚看到,雖然確實(shí)可以提供高可用性,但是以劃算且商業(yè)上合理的方式提供這種可靠性是具有挑戰(zhàn)性的。與大多數(shù)工程問(wèn)題一樣,無(wú)論是由于成本、復(fù)雜度、物理需求等何種原因,商業(yè)上不合理的解決方案都不能向用戶(或制造商)提供真正的好處。因此,需要的是以經(jīng)濟(jì)合理的方式提供數(shù)據(jù)流的可靠傳輸。此外,還應(yīng)該以如下方式來(lái)提供這種傳輸在面對(duì)傳輸這些數(shù)據(jù)流的網(wǎng)絡(luò)元件內(nèi)的故障時(shí),應(yīng)該對(duì)如此支持的服務(wù)引起最小的中斷。

發(fā)明內(nèi)容
應(yīng)用根據(jù)本發(fā)明的方法和系統(tǒng)的網(wǎng)絡(luò)元件滿足了前述需要,并且因此在其轉(zhuǎn)發(fā)引擎之一發(fā)生故障時(shí)能快速、有效地恢復(fù)服務(wù)。如隨后指出的那樣,這種技術(shù)(這里稱為“基于個(gè)體的切換”技術(shù))通過(guò)單獨(dú)處理每個(gè)轉(zhuǎn)發(fā)引擎、并且對(duì)適當(dāng)信息的復(fù)制一完成就執(zhí)行切換、并使網(wǎng)絡(luò)元件恢復(fù)服務(wù),實(shí)現(xiàn)了這一目的,而不需要等待一組轉(zhuǎn)發(fā)引擎完成它們各自的切換。使用這種基于個(gè)體的切換技術(shù),可以將入路徑的切換與出路徑的切換相分離,以進(jìn)一步改進(jìn)性能。這允許給定轉(zhuǎn)發(fā)引擎的入轉(zhuǎn)發(fā)路徑返回服務(wù),而該轉(zhuǎn)發(fā)引擎的出路徑仍在經(jīng)歷切換。此時(shí),轉(zhuǎn)發(fā)引擎的入路徑能夠向其他轉(zhuǎn)發(fā)引擎(其出路徑已經(jīng)完成切換,或者其沒(méi)有參與切換)轉(zhuǎn)發(fā)分組,這減少了恢復(fù)服務(wù)的時(shí)間。
在本發(fā)明的一個(gè)實(shí)施例中,公開(kāi)了一種方法,該方法包括接收轉(zhuǎn)發(fā)引擎應(yīng)該執(zhí)行切換操作的指示,并響應(yīng)于接收指示的步驟,執(zhí)行切換操作。切換操作包括在第一接口卡和第二接口卡之間切換轉(zhuǎn)發(fā)引擎的耦合。切換操作的執(zhí)行獨(dú)立于另一切換操作。其他切換操作由另一轉(zhuǎn)發(fā)引擎執(zhí)行。
在本發(fā)明的另一實(shí)施例中,公開(kāi)了一種方法,該方法包括接收轉(zhuǎn)發(fā)引擎已經(jīng)完成了切換操作的指示。在多個(gè)轉(zhuǎn)發(fā)引擎中的一個(gè)處接收到該指示。該方法還包括響應(yīng)于接收到轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作的指示,使多個(gè)轉(zhuǎn)發(fā)引擎之一確認(rèn)該指示。該轉(zhuǎn)發(fā)引擎是多個(gè)轉(zhuǎn)發(fā)引擎之一。
在本發(fā)明的另一實(shí)施例中,公開(kāi)了一種網(wǎng)絡(luò)元件中的故障恢復(fù)方法。該方法包括向多個(gè)轉(zhuǎn)發(fā)引擎指示轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作,并響應(yīng)于該指示,使這多個(gè)轉(zhuǎn)發(fā)引擎中至少一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)該轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作。
在本發(fā)明的另一實(shí)施例中,公開(kāi)了一種轉(zhuǎn)發(fā)引擎。該轉(zhuǎn)發(fā)引擎包括入口路徑、出口路徑和控制器。入口路徑和出口路徑彼此獨(dú)立。控制器被耦合以獨(dú)立地控制入口路徑和出口路徑。
前面是一個(gè)概述,所以包括必要的簡(jiǎn)化、歸納以及對(duì)細(xì)節(jié)的省略;因此,本領(lǐng)域的技術(shù)人員應(yīng)該理解,這個(gè)概述只是示例性的,并不是要做出任何限制。本領(lǐng)域的技術(shù)人員也應(yīng)該清楚,這里所公開(kāi)的操作可以以多種方式實(shí)現(xiàn),并且可以做出的這些改變和修改,而不脫離本發(fā)明及其更廣的方面。在下面的非限定性詳細(xì)描述中,由所附權(quán)利要求單獨(dú)規(guī)定的本發(fā)明的其他方面、創(chuàng)造性特征和優(yōu)點(diǎn)將變清楚。


通過(guò)參考附圖,本領(lǐng)域的技術(shù)人員可以更好地理解本發(fā)明,并且清楚其眾多的目的、特征和優(yōu)點(diǎn)。
圖1圖示了根據(jù)本發(fā)明的轉(zhuǎn)發(fā)引擎冗余方案的交換機(jī)的方框圖。
圖2A圖示了根據(jù)本發(fā)明實(shí)施例的端口卡的方框圖。
圖2B圖示了根據(jù)本發(fā)明實(shí)施例的轉(zhuǎn)發(fā)引擎的方框圖。
圖3圖示了由根據(jù)本發(fā)明實(shí)施例的過(guò)程執(zhí)行的動(dòng)作的流程圖。
圖4圖示了根據(jù)本發(fā)明的基本轉(zhuǎn)發(fā)引擎切換過(guò)程的示例的流程圖。
圖5A和5B圖示了根據(jù)本發(fā)明的示例最優(yōu)化轉(zhuǎn)發(fā)引擎切換過(guò)程的流程圖。
圖6圖示了路由處理器和正在經(jīng)歷切換的單個(gè)轉(zhuǎn)發(fā)引擎之間的基本切換協(xié)議。
圖7圖示了路由處理器和具有不同響應(yīng)時(shí)間的多個(gè)轉(zhuǎn)發(fā)引擎之間的互動(dòng)。
在不同附圖中使用相同的標(biāo)號(hào)指示相似或相同的項(xiàng)目。
具體實(shí)施例方式
下文意在提供對(duì)本發(fā)明的示例的詳細(xì)描述,而不應(yīng)該用來(lái)限制發(fā)明本身。相反地,多種改變可以落在由所附權(quán)利要求所定義的本發(fā)明的范圍之內(nèi)。
引言本發(fā)明以商業(yè)上合理的方式提供了數(shù)據(jù)流的可靠傳輸。通過(guò)提供冗余轉(zhuǎn)發(fā)引擎(FE)并支持在這些FE之間的快速和高效切換(switchover),在使用分離的端口卡和轉(zhuǎn)發(fā)引擎的網(wǎng)絡(luò)元件中獲得了這種可靠性。這種網(wǎng)絡(luò)元件通常使用N+L個(gè)FE(例如,N+1;其中N是端口卡的數(shù)目,L是冗余(或備用)FE的數(shù)目),以及在端口卡和FE之間的分布式交換結(jié)構(gòu)(也被稱為分布式結(jié)構(gòu),或者更簡(jiǎn)單地,稱為結(jié)構(gòu);其中有N個(gè)端口卡和M(=N+L)個(gè)FE)。
更具體地,這種網(wǎng)絡(luò)元件通過(guò)提供至少1:N冗余度的轉(zhuǎn)發(fā)引擎(或者,更一般地,L:N冗余度),向端口卡接口提供轉(zhuǎn)發(fā)引擎冗余,以提供高可用性的服務(wù)。具體地,這種網(wǎng)絡(luò)元件支持這樣一種機(jī)制,通過(guò)這種機(jī)制,一個(gè)轉(zhuǎn)發(fā)引擎可以接替另一(發(fā)生故障的)轉(zhuǎn)發(fā)引擎??墒沁@種方法的實(shí)現(xiàn)需要端口卡和轉(zhuǎn)發(fā)引擎之間的交換結(jié)構(gòu)。但是如果有其他更實(shí)際的限制(例如,需要緊湊的機(jī)架及受限的散熱),這種解決方案是不可行的。一種折衷方法是直接將端口卡接口互連到少量的(例如,兩個(gè))轉(zhuǎn)發(fā)引擎,據(jù)此形成分布式結(jié)構(gòu)。這不再需要端口卡接口和轉(zhuǎn)發(fā)引擎之間的傳統(tǒng)交換結(jié)構(gòu),并且使機(jī)架的散熱保持在可接受的水平。不幸的是,這種折衷方法使得提供從發(fā)生故障的轉(zhuǎn)發(fā)引擎到另一轉(zhuǎn)發(fā)引擎的快速切換的任務(wù)變得復(fù)雜得多,這是由于轉(zhuǎn)發(fā)引擎只連接到最多兩個(gè)端口卡接口的限制。具體地,問(wèn)題在于系統(tǒng)中發(fā)生故障的轉(zhuǎn)發(fā)引擎和空閑轉(zhuǎn)發(fā)引擎可能沒(méi)有(并且,通常都沒(méi)有)連接到相同的端口卡接口。
因而,本發(fā)明提供了一種方法和系統(tǒng),它們被設(shè)計(jì)來(lái)通過(guò)單獨(dú)處理每個(gè)轉(zhuǎn)發(fā)引擎,管理切換并且對(duì)適當(dāng)信息的復(fù)制一完成就使轉(zhuǎn)發(fā)引擎恢復(fù)服務(wù),而不需要等待一組轉(zhuǎn)發(fā)引擎完成它們的切換,來(lái)解決FE切換問(wèn)題。因?yàn)槭褂昧诉@樣的手段,所以這里將這種方法稱為“基于個(gè)體的切換”方法。
這種“基于個(gè)體的切換”方法也是可擴(kuò)展的。在一個(gè)實(shí)施例中,這種方法將給定FE的入(incoming)路徑的切換與該FE的出(outgoing)路徑的切換相隔離。這種方法允許給定轉(zhuǎn)發(fā)引擎的入轉(zhuǎn)發(fā)路徑返回服務(wù),而該FE的出路徑還在經(jīng)歷切換。這允許給定轉(zhuǎn)發(fā)引擎的入路徑將分組轉(zhuǎn)發(fā)到出路徑已經(jīng)完成切換或者未參與切換的其他轉(zhuǎn)發(fā)引擎。因而,使得從轉(zhuǎn)發(fā)引擎的切換到恢復(fù)服務(wù)的時(shí)間最小。
本發(fā)明具有許多優(yōu)點(diǎn)。使用這種方法和系統(tǒng)的網(wǎng)絡(luò)元件體系結(jié)構(gòu)在FE發(fā)生故障時(shí)能快速、高效地恢復(fù)服務(wù)。正如所指出的那樣,這種“基于個(gè)體的切換”技術(shù)通過(guò)單獨(dú)處理每個(gè)轉(zhuǎn)發(fā)引擎,對(duì)適當(dāng)信息的復(fù)制一完成就執(zhí)行切換并且使網(wǎng)絡(luò)元件恢復(fù)服務(wù),而不需要等待一組轉(zhuǎn)發(fā)引擎完成它們各自的切換,來(lái)實(shí)現(xiàn)這一優(yōu)點(diǎn)。使用這種基于個(gè)體的切換技術(shù),可以將入路徑的切換與出路徑的切換相隔離,以便進(jìn)一步改進(jìn)性能。這允許給定轉(zhuǎn)發(fā)引擎的入轉(zhuǎn)發(fā)路徑返回服務(wù),而該轉(zhuǎn)發(fā)引擎的出路徑還在經(jīng)歷切換。此時(shí),轉(zhuǎn)發(fā)引擎的入路徑能夠?qū)⒎纸M轉(zhuǎn)發(fā)到其他轉(zhuǎn)發(fā)引擎(其出路徑已經(jīng)完成切換,或者其沒(méi)有參與切換),這減少了恢復(fù)服務(wù)時(shí)間。
根據(jù)本發(fā)明的交換機(jī)在FE發(fā)生故障時(shí)提供了快速、高效的恢復(fù),而其在成本方面相對(duì)于隨后描述的可能解決方案是相當(dāng)或更低的。此外,端口卡和FE之間的連接不需要被路由通過(guò)中央復(fù)用器/解復(fù)用器,所以在連接性基礎(chǔ)結(jié)構(gòu)中(例如,在交換機(jī)的中板和/或背板中)不那么擁擠,除了其他優(yōu)點(diǎn)之外,這還降低了成本、改進(jìn)了可靠性并減少了散熱需要。并且,與使用中央復(fù)用器/解復(fù)用器的體系結(jié)構(gòu)相比,不需要設(shè)計(jì)高M(jìn)TBF的中央復(fù)用器/解復(fù)用器,可以預(yù)料這種中央復(fù)用器/解復(fù)用器需要其自身的冗余。這種冗余在中板/背板中還加入了更多的連接,以及關(guān)于該冗余的管理和該中央復(fù)用器/解復(fù)用器的故障轉(zhuǎn)移的更多的復(fù)雜度。但是,本發(fā)明允許以快速、高效的方式對(duì)分布式交換結(jié)構(gòu)進(jìn)行交換,這允許用戶享受可靠操作的優(yōu)點(diǎn),而不必忍受過(guò)長(zhǎng)的故障恢復(fù)時(shí)間。因而,通過(guò)解決對(duì)可靠性的需要,而同時(shí)將成本維持在相對(duì)低的水平,本發(fā)明以經(jīng)濟(jì)合理的方式滿足了用戶對(duì)可靠交換的需要。
示例網(wǎng)絡(luò)元件體系結(jié)構(gòu)圖1圖示了使用本發(fā)明的實(shí)施例所支持的冗余方案的網(wǎng)絡(luò)元件(這里是交換機(jī))的方框圖。圖1中圖示的交換機(jī)100包括多個(gè)端口卡(表示為端口卡110(1)~(N))、多個(gè)轉(zhuǎn)發(fā)引擎(表示為轉(zhuǎn)發(fā)引擎120(1)~(N+1))、路由處理器130和交換矩陣140。應(yīng)該注意,雖然這種情形不是一般性的(隨后將要指出),但是該圖中,端口卡的數(shù)目(N)與轉(zhuǎn)發(fā)引擎的數(shù)目(N+1;或者更一般的情形是M(=N+L))相關(guān)。路由處理器130被耦合以控制端口卡110(1)~(N)和轉(zhuǎn)發(fā)引擎120(1)~(N+1)。如圖1所示,端口卡110(1)~(N)和轉(zhuǎn)發(fā)引擎120(1)~(N+1)之間的連接,以及這些元件中的一部分組合在一起以代表分布式交換結(jié)構(gòu)150。分布式交換結(jié)構(gòu)150代表分布式復(fù)用器/解復(fù)用器布置,其提供對(duì)根據(jù)題為“METHOD AND SYSTEM FOR PROVIDINGREDUNDANCY WITHIN A NETWORK ELEMENT”(在網(wǎng)絡(luò)元件內(nèi)提供冗余的方法和系統(tǒng))的專利申請(qǐng)的N+1轉(zhuǎn)發(fā)引擎冗余方案所必需的連接度的支持,該專利申請(qǐng)結(jié)合于此用作參考。
在發(fā)生故障時(shí),路由處理器130通常會(huì)采取對(duì)轉(zhuǎn)發(fā)引擎120(1)~(N+1)中的故障作出反應(yīng)所必需的動(dòng)作。這是因?yàn)榘l(fā)生故障的轉(zhuǎn)發(fā)引擎可能不能夠完成切換,并且其他轉(zhuǎn)發(fā)引擎可能無(wú)法知道這個(gè)故障。這一因素也突出了每個(gè)FE能自己切換到其備用模式而不需要從另一FE(其可能發(fā)生了故障,并且不能提供這樣的信息)發(fā)送信息這種方法的優(yōu)點(diǎn)。
交換機(jī)100的體系結(jié)構(gòu)可以被歸納為在其中具有N個(gè)端口卡和M個(gè)FE的體系結(jié)構(gòu)。這種情形中,有N個(gè)主FE(這里也被稱為主FE)和L(其中L=M-N)個(gè)備用FE??梢砸远喾N方式實(shí)現(xiàn)端口卡到FE的互連,隨后將結(jié)合圖5和圖6所描述的示例對(duì)此進(jìn)行描述。在這種一般情形中,每個(gè)端口卡耦合到主FE和多個(gè)(L個(gè))備用FE。實(shí)際上,L的極限是N。這種臨界情形為每個(gè)端口卡提供了主FE和備用FE,所以這種布置在其所帶的限制下退化為與每個(gè)端口使用主FE和備份FE的體系結(jié)構(gòu)相似的體系結(jié)構(gòu)。
因而,每個(gè)端口卡通過(guò)主鏈路和L個(gè)備用鏈路耦合到其的對(duì)應(yīng)的L+1個(gè)FE。這里所使用的鏈路通常是某一種類的傳輸介質(zhì)(例如,光纜、同軸電纜等),并且雖然這可能包括各種類型的信號(hào)處理(放大、再生、帶寬定形等),但是這種傳輸介質(zhì)不包括從任一源(例如,端口卡或FE)到任一目的地(例如,分別是FE或端口卡)的任何數(shù)據(jù)流交換。本領(lǐng)域的技術(shù)人員會(huì)清楚,隨著數(shù)目L的增加,交換機(jī)中備用鏈路和FE的數(shù)目也會(huì)增加,并伴隨著復(fù)雜度和成本的增加。但是,通過(guò)具有多個(gè)備用FE所提供的MTBF(因而也是可靠性)的增加可以在一定程度上抵消這種復(fù)雜度和成本的增加,盡管這種抵消很可能隨著L的增加而趨于迅速減小,這使得大的L是相對(duì)不經(jīng)濟(jì)的(并且在臨界情形中,導(dǎo)致先前指出的成本限制)。使用這種體系結(jié)構(gòu),一個(gè)(或多個(gè))發(fā)生了故障的FE停止了服務(wù),并且受影響的端口卡(以及那些朝向備用FE的端口卡)移動(dòng)適當(dāng)數(shù)目的FE(等于發(fā)生故障的FE的數(shù)目)。因而,如果一個(gè)FE發(fā)生故障,則連接到該發(fā)生故障的FE和備用FE之間的FE的每個(gè)端口卡切換(移動(dòng))一個(gè)FE。需要交換的FE/端口卡的總數(shù)目等于發(fā)生故障的FE與備用FE之間的FE的數(shù)目。在一種情形中,這是以串行方式完成的,F(xiàn)E一個(gè)接一個(gè)地進(jìn)行交換,并且這里稱之為級(jí)聯(lián)技術(shù)。在題為“METHOD ANDSYSTEM FOR PROVIDING REDUNDANCY WITHIN A NETWORKELEMENT”(在網(wǎng)絡(luò)元件內(nèi)提供冗余的方法和系統(tǒng))的專利申請(qǐng)中對(duì)該技術(shù)進(jìn)行了更詳細(xì)地描述,該專利申請(qǐng)結(jié)合于此用作參考。
除了能夠處理多個(gè)同時(shí)發(fā)生的FE故障之外,這種體系結(jié)構(gòu)還能處理多個(gè)時(shí)間上連續(xù)的FE故障。因此,在第一FE發(fā)生故障并且受影響的端口卡被切換之后,另一故障導(dǎo)致新切換的端口卡的切換。以這種方式,使用這種體系結(jié)構(gòu)的交換機(jī)能夠在面臨多個(gè)FE故障時(shí)連續(xù)運(yùn)行。當(dāng)然,這種權(quán)衡是增加了復(fù)雜度和成本,但是在具有高得多的MTBF需求的給定應(yīng)用中,這可能是值得的。
應(yīng)該注意,在此處描述的附圖中的幾個(gè)實(shí)例中,變量標(biāo)識(shí)符“N”用來(lái)更簡(jiǎn)單地表示一系列相關(guān)或相似元件中的最后一個(gè)元件。這些變量標(biāo)識(shí)符的重復(fù)使用并不意味著這些元件系列的規(guī)模之間必然存在相關(guān)性,盡管這種相關(guān)性可能存在。這些變量標(biāo)識(shí)符的使用不需要每個(gè)系列的元件具有的元件數(shù)目與由同一變量標(biāo)識(shí)符限定的其他系列相同。相反地,在每個(gè)使用實(shí)例中,由“N”所標(biāo)識(shí)的變量(或者任何其他標(biāo)識(shí)符)可以具有與相同變量表示符的其他實(shí)例相同或不同的值。。
此外,關(guān)于這里所述的信號(hào),本領(lǐng)域的技術(shù)人員應(yīng)該認(rèn)識(shí)到,信號(hào)可以從第一方框直接傳輸?shù)降诙娇颍蛘咴诜娇蛑g可以修改信號(hào)(例如,放大、衰減、延遲、鎖存、緩沖、反相、濾波或其他修改)。雖然上述實(shí)施例中的信號(hào)被特征化為從一個(gè)方框傳輸?shù)较乱环娇?,但是本發(fā)明的其他實(shí)施例可以包括修改信號(hào),來(lái)代替這些直接傳輸?shù)男盘?hào),只要信號(hào)的信息和/或功能方面在方框之間傳輸。在某種程度上,在第二方框處輸入的信號(hào)可以被概念化為第二信號(hào),其是由于所包含的電路系統(tǒng)的物理限制(例如,不可避免地會(huì)有某些衰減和延遲),而從第一方框輸出的第一信號(hào)得到的。因此,這里所使用的從第一信號(hào)得到的第二信號(hào)包括第一信號(hào)或?qū)Φ谝恍盘?hào)的任何修改,無(wú)論這種修改是由于電路限制或是由于通過(guò)其他不改變第一信號(hào)的信息和/或最終功能方面的電路元件。
前面所述的實(shí)施例中不同的組件包含在不同的其他組件內(nèi)(例如,各種元件被表示為交換機(jī)100的組件)。應(yīng)該理解,這些描述的結(jié)構(gòu)只是示例,實(shí)際上,可以實(shí)現(xiàn)許多其他獲得相同功能的結(jié)構(gòu)。言簡(jiǎn)意賅地說(shuō),為了獲得相同功能的組件的任意排列被有效“關(guān)聯(lián)”,從而能獲得希望的功能。因此,此處被組合來(lái)獲得特定功能的任意兩個(gè)組件都可被視為彼此“關(guān)聯(lián)”,從而獲得希望的功能,而無(wú)論結(jié)構(gòu)或中間組件如何。同樣,這樣關(guān)聯(lián)的任意兩個(gè)組件也可以被視為彼此“可操作地連接”,或彼此“可操作地耦合”,以獲得希望的功能。
根據(jù)本發(fā)明所構(gòu)建的交換機(jī)(例如,交換機(jī)100)的重要特征是分布式交換結(jié)構(gòu)(例如,分布式交換結(jié)構(gòu)150)。與其他選擇相比,分布式交換結(jié)構(gòu)向端口卡和FE之間的互連需要提供了更簡(jiǎn)單、更有效且更優(yōu)雅的解決方案。這種簡(jiǎn)單性轉(zhuǎn)化為更好的可靠性(更高的MTBF)和更低的成本,因此比其他選擇更好地解決了用戶的需要。對(duì)N+1技術(shù)來(lái)說(shuō)更是如此,這一技術(shù)將分布式交換結(jié)構(gòu)減少為在每個(gè)端口卡和FE上的2輸入復(fù)用器/解復(fù)用器。將參考圖2A和圖2B更詳細(xì)地描述這種類型的結(jié)構(gòu)。
在典型的實(shí)施例中,轉(zhuǎn)發(fā)引擎包括兩部分入路徑(入口(ingress)路徑,其包括對(duì)從端口卡接口接收到的分組進(jìn)行處理的組件)和出路徑(出口(egress)路徑,其在將分組發(fā)送到端口卡接口之前對(duì)這些分組進(jìn)行進(jìn)一步處理)。通常,在端口卡接口中接收到的給定分組被傳遞到該端口卡接口所連接到的轉(zhuǎn)發(fā)引擎。該轉(zhuǎn)發(fā)引擎的入路徑對(duì)分組進(jìn)行處理,并經(jīng)由交換結(jié)構(gòu)將分組交換到另一轉(zhuǎn)發(fā)引擎,其出路徑在將分組發(fā)送到其他轉(zhuǎn)發(fā)引擎所連接到的端口卡接口之前對(duì)分組進(jìn)行進(jìn)一步處理。
作為在轉(zhuǎn)發(fā)引擎中的處理的一部分,通常會(huì)參考某些信息,例如轉(zhuǎn)發(fā)、訪問(wèn)控制列表(某種形式的過(guò)濾)以及其他這樣的信息。這種信息存儲(chǔ)在概念/邏輯表中,這些表存儲(chǔ)在隨機(jī)訪問(wèn)存儲(chǔ)器(RAM)形式的硬件中或者稱為“三重內(nèi)容可編址存儲(chǔ)器”(TCAM)的專用存儲(chǔ)器中。這一事實(shí)的重要性在于,雖然特定的轉(zhuǎn)發(fā)引擎設(shè)置有某一數(shù)量的存儲(chǔ)器,其形成能容納端口卡接口所預(yù)期的“合理”數(shù)量信息所需要的規(guī)模,但是通常不能假設(shè)該存儲(chǔ)器能存儲(chǔ)連接到該給定轉(zhuǎn)發(fā)引擎的兩個(gè)端口卡接口的信息。對(duì)于其中轉(zhuǎn)發(fā)引擎用作多個(gè)端口卡的備用FE的體系結(jié)構(gòu)更是如此。
結(jié)果,在執(zhí)行切換時(shí)必需考慮兩類一般的轉(zhuǎn)發(fā)引擎在轉(zhuǎn)發(fā)硬件中具有雙配置的轉(zhuǎn)發(fā)引擎(即,這種轉(zhuǎn)發(fā)引擎中的轉(zhuǎn)發(fā)硬件能容納連接到它的兩個(gè)端口卡接口的配置)和在轉(zhuǎn)發(fā)硬件中具有單配置的轉(zhuǎn)發(fā)引擎(即,這種轉(zhuǎn)發(fā)引擎中的轉(zhuǎn)發(fā)硬件僅能容納連接到它的端口卡接口中的一個(gè)的配置)。結(jié)果,在具有單配置的轉(zhuǎn)發(fā)引擎上,另一配置被保持在一般的存儲(chǔ)器中,并且該配置在切換時(shí)需要復(fù)制到轉(zhuǎn)發(fā)硬件存儲(chǔ)器。實(shí)際上,也可以考慮這樣的情形轉(zhuǎn)發(fā)引擎在其路徑之一中(例如,入路徑)具有雙配置能力,而在另一路徑中(例如,出路徑)具有單配置能力。
圖2A是端口卡200的方框圖。端口卡200代表圖1中的端口卡110(1)~(N)之一。如其名稱所示,端口卡200支持多個(gè)入站(inbound)端口和出站(outbound)端口,這些端口向其數(shù)據(jù)流需要被交換的網(wǎng)絡(luò)元件提供連接。圖2A中將這些連接表示為網(wǎng)絡(luò)輸入205(1)~(N)和網(wǎng)絡(luò)輸出210(1)~(N)。端口卡200還包括轉(zhuǎn)發(fā)引擎選擇器(表示為轉(zhuǎn)發(fā)引擎(FE)選擇器220)。FE選擇器220耦合到主轉(zhuǎn)發(fā)引擎(未示出)和備用FE(也未示出)。在正常情況中,選擇器220將端口卡200經(jīng)由主鏈路230耦合到其主轉(zhuǎn)發(fā)引擎。如果主轉(zhuǎn)發(fā)引擎發(fā)生故障,則選擇器220將端口卡200經(jīng)由備用鏈路240耦合到其備用轉(zhuǎn)發(fā)引擎。圖1中用實(shí)線示出了端口卡110(1)~(N)與轉(zhuǎn)發(fā)引擎120(1)~(N)之間的到主轉(zhuǎn)發(fā)引擎的連接。類似地,圖1中用虛線示出了端口卡110(1)~(N)和轉(zhuǎn)發(fā)引擎120(1)~(N+1)之間的端口卡和其備用轉(zhuǎn)發(fā)引擎之間的連接。
圖2B圖示了轉(zhuǎn)發(fā)引擎(表示為轉(zhuǎn)發(fā)引擎250)的示例的方框圖。轉(zhuǎn)發(fā)引擎250代表圖1中的轉(zhuǎn)發(fā)引擎120(1)~(N+1)之一。在把耦合到轉(zhuǎn)發(fā)引擎250的端口卡接收到的數(shù)據(jù)流所攜帶的信息向交換矩陣255傳遞時(shí),轉(zhuǎn)發(fā)引擎250控制該信息的轉(zhuǎn)發(fā)。清楚的是,交換矩陣255是交換矩陣140的示例。轉(zhuǎn)發(fā)引擎250作為主轉(zhuǎn)發(fā)引擎經(jīng)由主鏈路260a接收這些數(shù)據(jù)流,并且作為主轉(zhuǎn)發(fā)引擎經(jīng)由主鏈路260b發(fā)送數(shù)據(jù)流。類似地,轉(zhuǎn)發(fā)引擎250作為備用轉(zhuǎn)發(fā)引擎經(jīng)由備用鏈路265a接收數(shù)據(jù)流,并且作為備用轉(zhuǎn)發(fā)引擎經(jīng)由備用鏈路265b發(fā)送數(shù)據(jù)流。在圖2B中如此描述主鏈路和備用鏈路的接收和發(fā)送部分,從而使得更詳細(xì)地描述了轉(zhuǎn)發(fā)引擎250的體系結(jié)構(gòu)。分別由入站FE選擇器270和出站FE選擇器275(它們被一起稱為選擇單元276)執(zhí)行主鏈路260a和260b以及備用鏈路265a和265b之間的選擇。入站FE選擇器270提供從所選擇的鏈路到入站處理元件280的數(shù)據(jù)流。入站處理元件280然后在轉(zhuǎn)發(fā)控制器285的控制下將該數(shù)據(jù)流轉(zhuǎn)發(fā)到交換矩陣255。
相反地,由出站處理元件290對(duì)從交換矩陣255接收到的數(shù)據(jù)流進(jìn)行處理。出站處理元件290在轉(zhuǎn)發(fā)控制器285的控制下將該數(shù)據(jù)流傳遞到出站FE選擇器275,出站FE選擇器275接著通過(guò)主鏈路260b或備用鏈路265b將該數(shù)據(jù)流傳遞回預(yù)期的端口卡。雖然轉(zhuǎn)發(fā)控制器285包括一定數(shù)量的存儲(chǔ)器(例如,片上或緩存存儲(chǔ)器),但是經(jīng)常需要額外的存儲(chǔ)器(例如,為了存儲(chǔ)額外的配置信息)。圖2中將該額外存儲(chǔ)器表示為主存儲(chǔ)器(或者更簡(jiǎn)單地,存儲(chǔ)器)295,其耦合到轉(zhuǎn)發(fā)控制器285,并且例如是DRAM存儲(chǔ)器。也可以如圖2B所示,在入站處理元件280和出入處理元件290中,分別由緩存存儲(chǔ)器296和297提供配置信息的存儲(chǔ)。
如圖2B所示,除了其他組件之外,轉(zhuǎn)發(fā)引擎250可以被分為入口路徑298和出口路徑299。入口路徑298,這里也被稱為入站路徑,包括入站FE選擇器270和入站處理元件280。類似地,出口路徑299包括出站處理元件290和出站FE選擇器275。出口路徑299在這里也被稱為出站路徑。如在本文其他地方所描述的那樣,入口路徑298和出口路徑299的特征是它們的能獨(dú)立地被交換的能力,正如下述事實(shí)所示例的那樣將入站FE選擇器270和出站FE選擇275表示為分立的單元(盡管在物理上入站FE選擇器270和出站FE選擇器275可以包括在單個(gè)交換單元中(例如,使用相同的控制線路來(lái)控制))??刂破?85也是采用這種理念設(shè)計(jì)的,所以能夠獨(dú)立地交換這兩個(gè)路徑(例如,在軟件、固件或硬件的控制下),就如本文其他地方所描述的那樣。
配置信息(例如,用來(lái)將分組轉(zhuǎn)發(fā)到其預(yù)期目的地的每個(gè)源/目的地對(duì)的轉(zhuǎn)發(fā)條目)的存儲(chǔ)對(duì)這些網(wǎng)絡(luò)元件的操作是至關(guān)重要的。在FE充當(dāng)主FE時(shí)該FE所使用的配置信息這里被稱為主配置信息,而在FE充當(dāng)備用FE時(shí)該FE所使用的配置信息這里被稱為備用配置信息。因而,這意味著對(duì)這些信息的容易的訪問(wèn)對(duì)于其正確操作是至關(guān)重要的。通過(guò)將必需的信息存儲(chǔ)在經(jīng)濟(jì)上可行的最快速的存儲(chǔ)器中,來(lái)支持這種訪問(wèn)。如果這些配置信息不易訪問(wèn),則結(jié)果可能是丟失分組,并且因此不能向用戶提供高可用性網(wǎng)絡(luò)元件。
可以存儲(chǔ)FE配置信息的位置有多處,因此必須做出設(shè)計(jì)權(quán)衡。關(guān)于該信息被存儲(chǔ)在何處的決定受多種因素的影響。這些因素包括訪問(wèn)和存儲(chǔ)信息所需的時(shí)間、這樣的延遲在發(fā)生故障時(shí)對(duì)交換機(jī)的無(wú)縫操作的影響、在每個(gè)可能位置處的存儲(chǔ)器空間的大小和成本(通常,存儲(chǔ)器設(shè)置地離數(shù)據(jù)路徑越遠(yuǎn),該存儲(chǔ)器就越大且更便宜)、可用來(lái)作為緩存存儲(chǔ)器的集成電路(IC)面積以及其他這樣的考慮。例如,如果配置信息(主FE配置信息和備用FE配置信息)可以存儲(chǔ)在緩存存儲(chǔ)器296和297(較快,但是通常較小且更昂貴)中,則優(yōu)選地將該信息存儲(chǔ)在存儲(chǔ)器295(較慢,但是較大且更便宜)中。也可以從交換機(jī)的路由處理器中下載這些信息。這種權(quán)衡會(huì)影響配置信息存儲(chǔ)和讀取的方式,由此影響FE相互接替的方式。
因而,如果用于主FE和備用FE的信息(分別是主配置信息和備用配置信息)都能存儲(chǔ)在緩存存儲(chǔ)器296和297中,則切換將相對(duì)較快,但是這種解決方案很可能更昂貴(在成本和IC內(nèi)的面積需求方面)。相反地,如果用于主FE和備用FE的信息存儲(chǔ)在存儲(chǔ)器295中,則切換可能相對(duì)較慢,但是這種解決方案很可能更便宜。如果緩存存儲(chǔ)器296和297不是足夠大,以致不能容納全部的必要信息(即,只能容納一組配置信息(例如,主配置信息)),這可能迫使設(shè)計(jì)者如此構(gòu)造交換機(jī),從而在發(fā)生故障時(shí),從轉(zhuǎn)發(fā)控制器的存儲(chǔ)器復(fù)制備用配置信息,或者甚至從一個(gè)FE向另一FE復(fù)制備用配置信息(以前面所描述的方式)。
也應(yīng)該注意到,設(shè)計(jì)者可以通過(guò)將緩存存儲(chǔ)器296和297具有的尺寸設(shè)計(jì)為恰好足夠大,以致允許它們僅存儲(chǔ)用于一組配置信息的配置(例如,主FE配置),來(lái)選擇在速度和資源的使用效率之間達(dá)到平衡。備用FE配置則存儲(chǔ)在存儲(chǔ)器295中。這樣做的優(yōu)點(diǎn)是(通過(guò)使昂貴的片上緩存存儲(chǔ)器最小)使成本最小并高效地使用IC,同時(shí)通過(guò)在本地存儲(chǔ)備用信息使得控制消息流量最小(并且提高了使這些信息變?yōu)榭捎玫乃俣?,這是由于在存儲(chǔ)器295與緩存存儲(chǔ)器296和297之間可用的相對(duì)高速的傳輸)。
在處理N:M冗余度方案的更一般的情形中,可能的備用FE越多,必須存儲(chǔ)的配置就越多,因此需要更大的存儲(chǔ)器空間,并且需要端口卡和FE之間的多個(gè)備用鏈路。結(jié)果,這使得在緩存中存儲(chǔ)這些信息的選擇變得更加不切實(shí)際(或者甚至不可能),并且很可能變得更加昂貴。這些考慮促使使用更簡(jiǎn)單(且更便宜)的N+1冗余度方案,這是因?yàn)橹恍枰4嬷С謨蓚€(gè)FE所需的信息,所以需要較少的存儲(chǔ)器。但是,如下文指出的那樣,如果在兩種配置中有大量重復(fù),則還可以進(jìn)一步減小對(duì)存儲(chǔ)器空間的需求。
如此存儲(chǔ)/復(fù)制的信息可以不必是全部配置信息,而僅僅是將一個(gè)FE與另一FE相區(qū)分的信息。這可以使得這些信息的存儲(chǔ)可以更靠近數(shù)據(jù)路徑(例如,在緩存存儲(chǔ)器296和297中,或者至少在存儲(chǔ)器295中)。在L>1(或L>>1)的情形中這種技術(shù)是尤其有吸引力的,這是因?yàn)樵谶@種情形中,存儲(chǔ)器需求的減少可以使得在其他情況下不能實(shí)現(xiàn)的布置變?yōu)榭赡堋?br> 如果使用圖1所示的體系結(jié)構(gòu),一種最優(yōu)化方法認(rèn)可第N+1個(gè)FE(這里也被稱為備用FE)只需要加載有第N個(gè)FE的配置信息,并且第一個(gè)FE只需要加載有第N+1個(gè)FE的配置信息。這是因?yàn)榭偸侵辉谝环N狀態(tài)中(分別是備用FE和主FE)使用這兩個(gè)FE。因而,只有其他受影響的FE需要將它們的信息從一個(gè)FE復(fù)制到另一FE。應(yīng)該注意到,在替換體系結(jié)構(gòu)中,可以使用同時(shí)交換技術(shù),其中在每個(gè)FE內(nèi)存儲(chǔ)部分或所有配置信息。
還應(yīng)該注意到,無(wú)需排他地使用這些技術(shù)。取決于具體情況,可以使用同時(shí)切換和級(jí)聯(lián)切換的組合。例如,比較靠近故障的FE可以使用級(jí)聯(lián)技術(shù)來(lái)切換,而離發(fā)生故障的FE較遠(yuǎn)的那些FE可以使用同時(shí)技術(shù)(執(zhí)行最小限度的級(jí)聯(lián)轉(zhuǎn)變所需的時(shí)間已經(jīng)給出了準(zhǔn)備轉(zhuǎn)換的時(shí)間)?;蛘?,可以配置FE的組來(lái)同時(shí)切換。
可以在能夠使用根據(jù)本發(fā)明的技術(shù)的網(wǎng)絡(luò)元件中使用其他可替換的體系結(jié)構(gòu)或它們的組合。例如,一個(gè)這樣的實(shí)施例通過(guò)使備用FE處于FE的“中間”,減少了在主轉(zhuǎn)發(fā)引擎發(fā)生故障時(shí)切換到一個(gè)或多個(gè)備用轉(zhuǎn)發(fā)引擎所需的平均等待時(shí)間。在這種配置中,雖然備用轉(zhuǎn)發(fā)引擎在結(jié)構(gòu)上與網(wǎng)絡(luò)元件中其他轉(zhuǎn)發(fā)引擎沒(méi)有區(qū)別,但是其作為備用轉(zhuǎn)發(fā)引擎而被耦合到兩個(gè)端口卡,并且因此能夠通過(guò)選擇適當(dāng)?shù)膫溆面溌穪?lái)充當(dāng)這兩個(gè)端口卡中任一個(gè)的備用轉(zhuǎn)發(fā)引擎。在這種體系結(jié)構(gòu)中,切換只涉及發(fā)生故障的FE、備用FE和這兩者之間的FE。通過(guò)允許網(wǎng)絡(luò)元件的受影響端口卡各自選擇這些轉(zhuǎn)發(fā)引擎中的轉(zhuǎn)發(fā)引擎(包括備用轉(zhuǎn)發(fā)引擎)作為備用轉(zhuǎn)發(fā)引擎,這種體系結(jié)構(gòu)通過(guò)減少切換操作所牽涉的FE的數(shù)目,簡(jiǎn)化并加速了切換。
或者,可以使用輪轉(zhuǎn)調(diào)度(round-robin)方法。備用轉(zhuǎn)發(fā)引擎(例如,圖1中的轉(zhuǎn)發(fā)引擎120(N+1))可以耦合到第一個(gè)和最后一個(gè)端口卡(例如,如圖所示,分別是端口卡110(N)和端口卡110(1))。這種情形中,端口卡110(1)~(N)中每一個(gè)都耦合到三個(gè)轉(zhuǎn)發(fā)引擎主轉(zhuǎn)發(fā)引擎、在“順時(shí)針”方向的備用轉(zhuǎn)發(fā)引擎、以及在“逆時(shí)針”方向的備用轉(zhuǎn)發(fā)引擎。因此,取決于故障的位置,切換將涉及最少數(shù)目的FE(即,恢復(fù)涉及沿著發(fā)生故障的FE和備用FE之間的最短路線的FE(即,參與切換的轉(zhuǎn)發(fā)引擎的數(shù)目最少的方向))。實(shí)際上,這可以將備用FE放在“中間”,這樣該備用FE離最遠(yuǎn)的FE是等距的(假設(shè)網(wǎng)絡(luò)元件被完全填滿了端口卡/FE)。
此外,任何一項(xiàng)前述的體系結(jié)構(gòu)都可以用在“成組”的體系結(jié)構(gòu)中。使用這種體系結(jié)構(gòu),基本的體系結(jié)構(gòu)(或它們的變體)被劃分為組。備用轉(zhuǎn)發(fā)引擎支持這些組中的每個(gè)組。當(dāng)給定組的轉(zhuǎn)發(fā)引擎之一發(fā)生故障時(shí),由該組的適當(dāng)?shù)亩丝诳ā⑥D(zhuǎn)發(fā)引擎和備用轉(zhuǎn)發(fā)引擎選擇適當(dāng)?shù)膫溆面溌?,恢?fù)故障。以這種方式,適當(dāng)?shù)毓芾碓谠摻M的轉(zhuǎn)發(fā)引擎之一中的故障,而不干擾其他(一個(gè)或多個(gè))組。簡(jiǎn)單地說(shuō),通過(guò)加入備用轉(zhuǎn)發(fā)引擎,減少了等待時(shí)間,而增加了故障間平均時(shí)間,結(jié)果,這允許端口卡和轉(zhuǎn)發(fā)引擎被分為組。這些組中的每一個(gè)組雖然具有較少的端口卡和轉(zhuǎn)發(fā)引擎,但是都以與該組的基本體系結(jié)構(gòu)相似的方式工作,因此在任意給定情形中,只要執(zhí)行更少的切換。
在題為“METHOD AND SYSTEM FOR PROVIDING REDUNDANCYWITHIN A NETWORK ELEMENT”(在網(wǎng)絡(luò)元件內(nèi)提供冗余的方法和系統(tǒng))的專利申請(qǐng)中對(duì)上述體系結(jié)構(gòu)和替換進(jìn)行了更詳細(xì)地描述,該專利申請(qǐng)結(jié)合于此用作參考。
轉(zhuǎn)發(fā)引擎切換的基本示例圖3一般性地圖示了由根據(jù)實(shí)現(xiàn)本發(fā)明實(shí)施例的網(wǎng)絡(luò)元件(例如,諸如交換機(jī)100之類的網(wǎng)絡(luò)元件)的過(guò)程所執(zhí)行的動(dòng)作的流程圖。該過(guò)程開(kāi)始于由端口卡和轉(zhuǎn)發(fā)引擎選擇主鏈路來(lái)提供這些元件之間的連接(步驟300)。一旦選定了主鏈路,則交換機(jī)的路由處理器等待在活動(dòng)轉(zhuǎn)發(fā)引擎之一中發(fā)生故障的指示(步驟310)。如果不發(fā)生這些故障,則該過(guò)程只循環(huán)。如果發(fā)生了這種故障,則由受影響的端口卡和轉(zhuǎn)發(fā)引擎選擇一個(gè)或多個(gè)備用鏈路。可以以多種方式中的任意一種來(lái)完成這種切換。例如,可以在交換機(jī)的路由處理器的控制下,同時(shí)對(duì)所有這些受影響的鏈路執(zhí)行交換,如圖3所示,無(wú)論使用級(jí)聯(lián)技術(shù)或其他技術(shù)。但是,就像指出的那樣,使用級(jí)聯(lián)的方法通常要慢得多。在同時(shí)切換過(guò)程中,路由處理器使連接到發(fā)生故障的轉(zhuǎn)發(fā)引擎的端口卡切換到其備用鏈路,并且使該端口卡的備用轉(zhuǎn)發(fā)引擎也切換到備用鏈路,以支持該端口卡(步驟320)。大約在此時(shí),也切換其他(受影響的)FE。通過(guò)(大約)在相同時(shí)間執(zhí)行切換,可以并行執(zhí)行與切換受影響的FE相關(guān)的大部分工作,這節(jié)省了時(shí)間,并盡可能地使切換變?yōu)闊o(wú)縫。此時(shí)可以更換已經(jīng)被切換出服務(wù)的發(fā)生故障的轉(zhuǎn)發(fā)引擎。
這樣,路由處理器只配置受影響的端口卡和轉(zhuǎn)發(fā)引擎,以便(大約)在相同時(shí)間分別切換到它們的相應(yīng)備用轉(zhuǎn)發(fā)引擎/端口卡。以這種方式,轉(zhuǎn)發(fā)引擎被配置來(lái)支持這種端口卡,對(duì)于該端口卡那些轉(zhuǎn)發(fā)引擎是備用轉(zhuǎn)發(fā)引擎,并且因此優(yōu)選地,在某些容易訪問(wèn)的位置中存儲(chǔ)它們的備用配置信息,以便在發(fā)生故障時(shí)快速可用。但是,這意味著每個(gè)轉(zhuǎn)發(fā)引擎需要支持這些配置信息(主連接和備用連接)的某種方式的存儲(chǔ),因而可以不需要相對(duì)長(zhǎng)的延遲就能完成切換,其中相對(duì)長(zhǎng)的延遲是從一個(gè)轉(zhuǎn)發(fā)引擎復(fù)制配置信息到另一轉(zhuǎn)發(fā)引擎引起的。
正如指出的那樣,圖3圖示了根據(jù)本發(fā)明一個(gè)實(shí)施例的過(guò)程的流程圖。應(yīng)該理解,這里所討論的操作可以由計(jì)算機(jī)系統(tǒng)用戶直接鍵入的命令或?qū)S糜布K所執(zhí)行的步驟組成,但是優(yōu)選實(shí)施例包括軟件模塊所執(zhí)行的步驟。這里所稱的步驟的功能可以與模塊或模塊的一部分的功能相對(duì)應(yīng)。
這里所稱的操作可以是模塊(例如,軟件、固件或硬件模塊)或模塊的一部分。例如,雖然所述實(shí)施例包括軟件模塊并且/或者包括手動(dòng)鍵入的用戶命令,但是各種示例模塊可以是專用硬件模塊。這里所述的軟件模塊可以包括腳本、批處理或其他可執(zhí)行文件,或者這些文件的組合和/或這些文件的一部分。軟件模塊可以包括編碼在計(jì)算機(jī)可讀介質(zhì)中的計(jì)算機(jī)程序或其子程序。
另外,本領(lǐng)域的技術(shù)人員會(huì)認(rèn)識(shí)到,模塊之間的邊界只是示例性的,并且其他實(shí)施例可以將模塊合并,或者將模塊的功能做其他分解。例如,這里所述的模塊可以被分解為子模塊,它們可以被當(dāng)作多個(gè)計(jì)算機(jī)進(jìn)程執(zhí)行,或者可選地在多個(gè)計(jì)算機(jī)上執(zhí)行。此外,其他實(shí)施例可以將特定模塊或子模塊的多個(gè)實(shí)例組合起來(lái)。另外,本領(lǐng)域的技術(shù)人員將認(rèn)識(shí)到,在示例實(shí)施例中描述的操作只是示例性的。根據(jù)本發(fā)明,可以將操作組合,或者將操作的功能分散到另外的操作中。
或者,可以在實(shí)現(xiàn)這些功能的電路系統(tǒng)的結(jié)構(gòu)中包含這些動(dòng)作,例如復(fù)雜指令集計(jì)算機(jī)(CISC)的微碼、編程在可編程或可擦除/可編程器件中的固件、現(xiàn)場(chǎng)可編程門陣列(FPGA)的配置、門陣列或全定制專用集成電路(ASIC)的設(shè)計(jì)等等。
流程圖中的每個(gè)方框可以由一個(gè)模塊(例如,軟件模塊)或一個(gè)模塊的一部分或計(jì)算機(jī)系統(tǒng)用戶來(lái)執(zhí)行。因此,可以在被配置來(lái)執(zhí)行上述方法的操作的計(jì)算機(jī)系統(tǒng)上執(zhí)行上述方法、其操作以及用于其的模塊,并且/或者可以從計(jì)算機(jī)可讀介質(zhì)執(zhí)行上述方法、其操作以及用于其的模塊??梢栽谟脕?lái)配置計(jì)算機(jī)系統(tǒng)以執(zhí)行該方法的機(jī)器可讀和/或計(jì)算機(jī)可讀介質(zhì)中包括該方法。這樣,可以將軟件模塊存儲(chǔ)在計(jì)算機(jī)系統(tǒng)存儲(chǔ)器中和/或發(fā)送到計(jì)算機(jī)系統(tǒng)存儲(chǔ)器,以配置計(jì)算機(jī)系統(tǒng)來(lái)執(zhí)行模塊的功能。
這樣的計(jì)算機(jī)系統(tǒng)通常根據(jù)程序(一列內(nèi)部存儲(chǔ)的指令,諸如具體的應(yīng)用程序和/或操作系統(tǒng))來(lái)處理信息,并且經(jīng)由I/O設(shè)備產(chǎn)生結(jié)果輸出信息。計(jì)算機(jī)進(jìn)程通常包括正在執(zhí)行(正在運(yùn)行)的程序或程序的一部分、當(dāng)前程序值和狀態(tài)信息、以及操作系統(tǒng)用來(lái)管理該進(jìn)程的執(zhí)行的資源。父進(jìn)程可以產(chǎn)生其他子進(jìn)程,以幫助執(zhí)行父進(jìn)程的整體功能。因?yàn)楦高M(jìn)程專門產(chǎn)生子進(jìn)程來(lái)執(zhí)行父進(jìn)程的整體功能的一部分,所以子進(jìn)程(以及孫進(jìn)程)執(zhí)行的功能有時(shí)可以被描述為由父進(jìn)程執(zhí)行的功能。
這樣的計(jì)算機(jī)系統(tǒng)通常包括多個(gè)“并發(fā)”執(zhí)行的計(jì)算機(jī)進(jìn)程。計(jì)算機(jī)系統(tǒng)經(jīng)常包括單處理單元,其能夠交替支持許多活動(dòng)進(jìn)程。雖然多個(gè)進(jìn)程可能看起來(lái)被并發(fā)執(zhí)行,但是在任意給定時(shí)間點(diǎn),單處理單元實(shí)際上只執(zhí)行一個(gè)進(jìn)程。通過(guò)快速改變進(jìn)程執(zhí)行,計(jì)算機(jī)系統(tǒng)看起來(lái)就像并發(fā)執(zhí)行進(jìn)程一樣。計(jì)算機(jī)系統(tǒng)的在執(zhí)行的各個(gè)階段中在多個(gè)進(jìn)程之間共享資源的能力能力被稱為多任務(wù)。具有多個(gè)處理單元的系統(tǒng)被稱為多處理系統(tǒng),其中多處理單元的定義是能支持真正的并發(fā)處理。當(dāng)活動(dòng)進(jìn)程在多任務(wù)環(huán)境和/多處理環(huán)境中被執(zhí)行時(shí),這些進(jìn)程常常被稱作并發(fā)執(zhí)行。
這里所述的軟件模塊可以由這樣的計(jì)算機(jī)系統(tǒng)例如從計(jì)算機(jī)可讀介質(zhì)接收。計(jì)算機(jī)可讀介質(zhì)可以被永久地、可拆卸地或遠(yuǎn)程地耦合到計(jì)算機(jī)系統(tǒng)。例如,計(jì)算機(jī)可讀介質(zhì)可以非排他地包括下列介質(zhì)中的任意多個(gè)磁存儲(chǔ)介質(zhì),包括磁盤和磁帶存儲(chǔ)介質(zhì);光存儲(chǔ)介質(zhì),諸如光盤介質(zhì)(例如,CD-ROM、CD-R等)和數(shù)字視頻盤存儲(chǔ)介質(zhì);非易失性存儲(chǔ)器存儲(chǔ)介質(zhì),包括基于半導(dǎo)體的存儲(chǔ)器單元,諸如閃存、EEPROM、EPROM、EOM或?qū)S眉呻娐罚灰资源鎯?chǔ)介質(zhì),包括寄存器、緩沖器或緩存、主存儲(chǔ)器、RAM等;以及數(shù)據(jù)傳輸介質(zhì),包括計(jì)算機(jī)網(wǎng)絡(luò)、點(diǎn)對(duì)點(diǎn)遠(yuǎn)程通信和載波傳輸介質(zhì)。在基于UNIX的實(shí)施例中,軟件模塊可以包含在文件(其可以是設(shè)備、終端、本地或遠(yuǎn)程文件)、套接字、網(wǎng)絡(luò)連接、信號(hào)或其他通信或狀態(tài)變化的手段中??梢允褂闷渌碌囊约案鞣N類型的計(jì)算機(jī)可讀介質(zhì)來(lái)存儲(chǔ)和/或傳輸這里所述的軟件模塊。
應(yīng)該注意,取決于實(shí)現(xiàn)方式,結(jié)合圖3討論的轉(zhuǎn)變可能導(dǎo)致兩個(gè)端口卡在短暫的一段時(shí)間中耦合到相同F(xiàn)E。如果這可以在給定設(shè)計(jì)中發(fā)生,則應(yīng)該將FE設(shè)計(jì)為從多個(gè)端口卡接受數(shù)據(jù)流,并正確地轉(zhuǎn)發(fā)該信息。清楚的是,這種系統(tǒng)中的FE還應(yīng)該被設(shè)計(jì)為在相同時(shí)間耦合到多個(gè)鏈路。相反地,這種系統(tǒng)的端口卡必須能夠通過(guò)其主鏈路和備用鏈路來(lái)接收數(shù)據(jù)流。這些能力確保了數(shù)據(jù)在這樣的轉(zhuǎn)變期間不會(huì)丟失。
還應(yīng)注意,無(wú)論在實(shí)施本發(fā)明的實(shí)施例時(shí)用于向FE提供編程的方法如何,到備用FE的切換都應(yīng)該是有狀態(tài)的(即,維持關(guān)于發(fā)生故障的FE的狀態(tài)信息,以便允許就像沒(méi)有發(fā)生故障一樣處理?yè)?jù)此被切換的數(shù)據(jù)流)。正如指出的那樣,這可以通過(guò)預(yù)先將必要的信息編程到每個(gè)FE中,或者通過(guò)將信息從一個(gè)FE復(fù)制到另一FE,或者通過(guò)某些其他方法(例如,通過(guò)從交換機(jī)的路由處理器下載這些信息)來(lái)完成。這是重要的特征,因?yàn)槠渲С纸粨Q機(jī)在面對(duì)FE故障時(shí)維持正被交換的數(shù)據(jù)流的能力。
替代切換技術(shù)在這里所討論的網(wǎng)絡(luò)元件中,可以使用各種技術(shù)來(lái)切換轉(zhuǎn)發(fā)引擎。這些方法包括如下這些。
1)這里被稱為“同時(shí)切換”方法的一種方法,其中每個(gè)FE存儲(chǔ)在切換情況中可能需要的所有可能配置的完整配置(例如,主配置和備用配置)。但是,這種方法只適用于這樣的配置其中所有轉(zhuǎn)發(fā)引擎例如都是雙配置類型。
2)這里被稱為“級(jí)聯(lián)切換”方法的另一種方法,其適用于任意類型的轉(zhuǎn)發(fā)引擎。但是,這種方法不能在最優(yōu)數(shù)量的時(shí)間中完成FE的切換和恢復(fù)服務(wù),因?yàn)槿缦惹爸赋龅哪菢?,切換必須級(jí)聯(lián)通過(guò)FE/端口卡。
3)也可以使用這里被稱為“改進(jìn)的同時(shí)切換”的另一種方法,但是其有它自身的限制。雖然這種方法適用于任何轉(zhuǎn)發(fā)引擎配置,但是這種方法強(qiáng)迫所有轉(zhuǎn)發(fā)引擎的切換以步伐一致(lockstep)方式進(jìn)行。因此,雖然控制簡(jiǎn)單,但是這種方法為了等待單配置轉(zhuǎn)發(fā)引擎的切換,影響了提供雙配置的轉(zhuǎn)發(fā)引擎的恢復(fù)服務(wù)時(shí)間。
4)“基于組”的切換,與先前討論的方式相似,其將轉(zhuǎn)發(fā)引擎的集合分為兩個(gè)組雙配置的轉(zhuǎn)發(fā)引擎和單配置的轉(zhuǎn)發(fā)引擎,并且以步伐一致的方式執(zhí)行每個(gè)組的切換。雖然這種方法改進(jìn)了雙配置轉(zhuǎn)發(fā)引擎的恢復(fù)服務(wù)時(shí)間,但是該方法還是將單配置轉(zhuǎn)發(fā)引擎限制為單獨(dú)的一組,并且這個(gè)單獨(dú)的配置組的成員還可能具有差別非常大的切換時(shí)間,這是因?yàn)樵谄溆布碇锌梢源鎯?chǔ)的信息量不一樣。另外,實(shí)際上,雙配置FE不是常例,而是例外。實(shí)際上,盡管可以在入口路徑中使用雙配置FE,但是設(shè)計(jì)約束可能要求在出路徑上使用單配置FE。
因而,雖然上述方法在發(fā)生故障及隨后進(jìn)行切換時(shí)可以提供可接受的性能,但是希望如果可能的話,在這些情形中提供改進(jìn)的性能。下面描述的技術(shù)提供了這種改進(jìn)的性能。
最優(yōu)化切換技術(shù)的示例根據(jù)本發(fā)明的方法和系統(tǒng)提供了針對(duì)FE切換問(wèn)題的一種設(shè)計(jì),其單獨(dú)處理每個(gè)轉(zhuǎn)發(fā)引擎,管理切換,并且適當(dāng)信息的復(fù)制一完成就使轉(zhuǎn)發(fā)引擎恢復(fù)服務(wù),而不需要等待一組轉(zhuǎn)發(fā)引擎完成它們的切換。由于所使用的手段,這種方法在這里被稱為“基于個(gè)體的切換”方法。
這種“基于個(gè)體的切換”方法也是可擴(kuò)展的。在一個(gè)實(shí)施例中,這種方法將給定FE的入路徑的切換與該FE的出路徑的切換相隔離。這種方法允許給定轉(zhuǎn)發(fā)引擎的入轉(zhuǎn)發(fā)路徑返回服務(wù),而該FE的出路徑還在經(jīng)歷切換。這允許給定轉(zhuǎn)發(fā)引擎的入路徑將分組轉(zhuǎn)發(fā)到出路徑已經(jīng)完成切換或者未參與切換的其他轉(zhuǎn)發(fā)引擎。因而,使得從轉(zhuǎn)發(fā)引擎的切換到恢復(fù)服務(wù)的時(shí)間最小。
使用先前所述的網(wǎng)絡(luò)元件體系結(jié)構(gòu)作為示例,可以看到,可以使得路由處理器(RP)負(fù)責(zé)協(xié)調(diào)受影響的FE的切換。正如指出的那樣,根據(jù)本發(fā)明實(shí)施例的切換方案通過(guò)允許并行執(zhí)行大多數(shù)(如果不是全部的話)切換操作,使切換時(shí)間和服務(wù)的恢復(fù)最小,因而消除了會(huì)增加切換所需時(shí)間的順序操作。
在這種方案中,每個(gè)FE單獨(dú)地經(jīng)歷切換。然后,對(duì)每個(gè)FE而言,只要任何FE(包括該FE自身)一準(zhǔn)備好向其發(fā)送流量,則該FE就恢復(fù)服務(wù)。當(dāng)較慢的FE(即,需要較長(zhǎng)時(shí)間來(lái)指示其發(fā)送流量的能力的FE)準(zhǔn)備向給定FE發(fā)送流量時(shí),使得較慢的FE能夠發(fā)送流量(即,去除從該FE到剛變?yōu)闇?zhǔn)備好發(fā)送流量的FE的流控制)。
給定的FE基于其當(dāng)前配置,可能需要不同的時(shí)間量來(lái)切換。例如,可以導(dǎo)致切換所必需的時(shí)間量不同的三種不同配置包括1)單配置(存儲(chǔ)在緩存存儲(chǔ)器中)的FE,2)入FE(IFE)雙配置而出FE(OFE)單配置的FE,和3)雙配置的FE。因?yàn)樾枰?或不需要)從FE的主存儲(chǔ)器將配置信息復(fù)制到入口和/或出口路徑的緩存存儲(chǔ)器,所以這些配置中的每一個(gè)在切換所必需的時(shí)間方面都不同。
在單配置中,F(xiàn)E內(nèi)的給定路徑支持僅包括活動(dòng)配置的緩存存儲(chǔ)器。備用配置存儲(chǔ)在主存儲(chǔ)器中。因此,這種體系結(jié)構(gòu)需要對(duì)給定路徑的硬件的完全重編程,所以通常需要最多的時(shí)間。具有IFE雙配置和OFE單配置的FE是混合解決方案,其中入口路徑表具有被編程于其中的活動(dòng)配置和備用配置,而出口路徑表只具有被編程于其中的活動(dòng)配置。由此,切換只需對(duì)出口路徑表進(jìn)行重編程。結(jié)果,這種體系結(jié)構(gòu)相對(duì)于單配置而言需要較少的時(shí)間來(lái)重編程,但是相對(duì)于雙配置而言則需要較多的時(shí)間。最后,支持雙配置的FE需要相對(duì)少的時(shí)間來(lái)切換,這是由于路徑的硬件表已經(jīng)加載有活動(dòng)配置和備用配置。
為了適應(yīng)這些切換所需的不同時(shí)間量,根據(jù)本發(fā)明的一種方法使得每個(gè)切換盡可能獨(dú)立(與其他FE的切換),而不強(qiáng)迫一個(gè)FE去等待另一FE的任務(wù)的完成。這允許每個(gè)FE能盡可能快的進(jìn)行切換,同時(shí)使得系統(tǒng)受切換操作影響的時(shí)間最小。
對(duì)這種方法的一種優(yōu)化通過(guò)將入轉(zhuǎn)發(fā)引擎(IFE)和出轉(zhuǎn)發(fā)引擎(OFE)的切換分離,允許更快的服務(wù)恢復(fù)。因而,當(dāng)IFE已經(jīng)對(duì)它的表重編程時(shí)(如果需要任何這樣的重編程的話),再次允許入口流量流動(dòng),而不必等待OFE。這允許分組從IFE到達(dá)不直接參與切換或者雖然直接參與切換但是已經(jīng)完成切換的FE的OFE。
基本的FE切換圖4圖示了基本的FE切換過(guò)程的流程圖。首先,網(wǎng)絡(luò)元件的RP得知FE發(fā)生故障(步驟400),結(jié)果,將該FE標(biāo)記為FAILED(步驟410),并開(kāi)始關(guān)閉該故障FE的進(jìn)程(步驟420)。應(yīng)該注意,通常,RP中的軟件實(shí)體(例如,系統(tǒng)診斷或管理軟件)隨后在嘗試判斷不需要其他硬件介入是否能恢復(fù)該FE時(shí),會(huì)嘗試以多種方式之一(例如,向該FE循環(huán)供電,重新加載該FE,或其他這樣的技術(shù))來(lái)恢復(fù)該FE。
接著,RP判斷是否有適當(dāng)?shù)目臻eFE可用(步驟430)。應(yīng)該注意,雖然在網(wǎng)絡(luò)元件內(nèi)可能存在空閑FE,但是該空閑FE可能并不處于對(duì)該特定故障條件有用的機(jī)架位置中。如果能找到(當(dāng)前冗余域的)空閑FE(步驟430),則RP判定切換將直接涉及哪個(gè)FE(步驟440)。通常,位于發(fā)生故障的FE和該空閑FE之間的所有FE都直接參與切換。形成切換列表(步驟450),并且發(fā)起現(xiàn)在所描述的過(guò)程。否則,故障是不可恢復(fù)的,并且向系統(tǒng)操作者指示錯(cuò)誤(步驟470)。
最優(yōu)化的FE切換過(guò)程示例在討論示例切換過(guò)程之前,應(yīng)該回顧在其描述中所使用的術(shù)語(yǔ)。從RP發(fā)送到FE#x的消息MESSAGE_1被稱為MESSAGE_1(x)。從RP發(fā)送到FE#x的消息MESSAGE_2(關(guān)于涉及FE#y的某些操作)被稱為MESSAGE_2(x,y)。從FE#x發(fā)送到RP的消息MESSAGE_3被稱為MESSAGE_3(x),而從FE#x發(fā)送到RP的消息MESSAGE_4(關(guān)于涉及FE#y的某些操作)被稱為MESSAGE_4(x,y)。
圖5A和圖5B圖示了根據(jù)本發(fā)明的示例最優(yōu)化FE切換過(guò)程的流程圖。這一過(guò)程例如可以如下構(gòu)建。
1)RP將對(duì)使用其總線的端口卡支配地位(mastership)的控制切換到端口卡(步驟500)。支配地位從活動(dòng)FE改變到備用FE。這允許備用FE控制到端口卡的鏈路。
2)RP向直接參與切換的所有FE#x(即,在發(fā)生故障的FE(要被更換的FE)和空閑FE之間的所有FE)發(fā)送SWITCHOVER_INITIATE(x)命令(步驟505)。RP還啟動(dòng)持續(xù)T秒的全局切換定時(shí)器(TIMER(x,Ts)),以監(jiān)控來(lái)自FE#x的消息(在這里被稱作FE_REPROGRAM_COMPLETE(x)消息)的最終接收。(如果TIMER(x,Ts)期滿,則指示錯(cuò)誤條件,并且對(duì)其進(jìn)行適當(dāng)處理)。
3)一旦接收到SWITCHOVER_INITIATE(x)命令,則FE#x執(zhí)行下述操作(步驟510)a)停止入口流量(應(yīng)該注意,停止入口流量避免了轉(zhuǎn)發(fā)硬件(正嘗試轉(zhuǎn)發(fā)分組)和CPU(正嘗試對(duì)這些相同的表重編程)對(duì)硬件表的并發(fā)訪問(wèn),因此加速了重編程);b)執(zhí)行涉及FE入口路徑的處理(例如,允許入口緩沖區(qū)排空、讀取入口統(tǒng)計(jì)數(shù)據(jù)等);c)對(duì)入口相關(guān)的硬件表重編程(如果任何這種重編程是必需的話);和d)將任何剩余的入口緩沖區(qū)都轉(zhuǎn)儲(chǔ)清空(如果希望/必要的話),并且允許輸出緩沖區(qū)排空。
應(yīng)該注意,F(xiàn)E的控制器使用已經(jīng)在FE控制器的主存儲(chǔ)器中的備用配置來(lái)對(duì)入口相關(guān)的硬件表編程。這可能是這樣一種情形特定的FE可以在入口路徑的緩存存儲(chǔ)器中存儲(chǔ)活動(dòng)配置和備用配置。如果是這種情形,則不必對(duì)硬件表執(zhí)行實(shí)際的編程。
4)一旦完成對(duì)入口相關(guān)硬件表的重編程(應(yīng)該注意,在雙配置FE中,概念上的重編程不花費(fèi)時(shí)間),F(xiàn)E#x就執(zhí)行下列操作(步驟515)a)請(qǐng)求對(duì)從其他FE和RP數(shù)據(jù)路徑到FE#x的單播和多播流的流控制;b)執(zhí)行涉及FE出口路徑的處理(例如,將出路徑緩沖區(qū)轉(zhuǎn)儲(chǔ)清空);和c)將來(lái)自正連接到FE#x中的端口卡的鏈路切換到來(lái)自將要被連接到FE#x的新端口卡的鏈路。
此時(shí),開(kāi)始處理連接到FE#x的新端口卡的入口流量,并將其轉(zhuǎn)發(fā)到所有沒(méi)有流控制的FE#x。尚未完成切換的那些FE的流量將在適當(dāng)?shù)拿慷丝?每?jī)?yōu)先級(jí)緩沖隊(duì)列中積累,一旦這些流量各自的FE完成它們的切換,并且去除了它們向FE#x的流控制,就最終允許這些流量再次流動(dòng)。
5)FE#x然后等待其出緩沖區(qū)排空(步驟520),此時(shí)除了其他潛在操作之外,F(xiàn)E#x開(kāi)始對(duì)出口相關(guān)的硬件表進(jìn)行重編程(如果任何這樣的重編程是必需的話)(步驟525和530)。
6)當(dāng)完成對(duì)出口相關(guān)硬件表的重編程時(shí)(在雙配置FE中,概念上的重編程不花費(fèi)時(shí)間),F(xiàn)E#x向RP發(fā)送FE_REPROGRAM_COMPLETE(x),從RP去除對(duì)單播和多播的流控制(步驟535、536和537),并且開(kāi)始檢查以判斷是否有任何SWITCHOVER_ADVERTISE消息要處理(步驟540)。
7)一旦RP從FE#z接收到FE_REPRPGRAM_COMPLETE(z)消息(步驟540),RP就向系統(tǒng)中所有FE#y(即,直接參與切換的所有FE,以及未直接參與切換的所有FE)發(fā)送SWITCHOVER_ADVERTISE(y,z)消息(步驟545)。在該SWITCHOVER_ADVERTISE(y,z)消息中,RP請(qǐng)求a)更新與FE#z將要替換的FE相關(guān)的“交換結(jié)構(gòu)端口映射表”條目(即,可以是這種情形,在該情形中,請(qǐng)求用FE#z的交換端口結(jié)構(gòu)更新與FE#(z-1)或FE#(z+1)相對(duì)應(yīng)的“交換結(jié)構(gòu)端口映射表”條目);和b)在硬件表中更新所有受切換影響的多播條目。
例如,如果RP從FE#3接收到FE_REPRPGRAM_COMPLETE(3)消息,則其向所有FE#y發(fā)送SWITCHOVER_ADVERTISE(y,3)消息,請(qǐng)求更新表(具體地,如果FE#3將接替FE#2的話,則請(qǐng)求更新用于FE#2的“交換結(jié)構(gòu)端口映射表”;以及請(qǐng)求更新指定直接參與切換的FE之一的多播條目)。同樣,當(dāng)RP從FE#4接收到FE_REPRPGRAM_COMPLETE(4)消息時(shí),RP向所有FE#y發(fā)送SWITCHOVER_ADVERTISE(y,4)消息,請(qǐng)求更新表(具體地,如果FE#4將接替FE#3的話,則請(qǐng)求更新用于FE#3的“交換結(jié)構(gòu)端口映射表”;以及請(qǐng)求更新指定直接參與切換的FE之一的多播條目)。
8)無(wú)論FE#x何時(shí)接收到SWITCHOVER_ADVERTISE(x,w),F(xiàn)E#x都執(zhí)行一定的動(dòng)作(步驟550)。
圖5B圖示了這些動(dòng)作的流程圖
a)如果FE#x是未直接參與切換的FE(即,沒(méi)有接收到SWITCHOVER_INITIATE(x)消息的FE)(步驟570),則FE#x立即執(zhí)行所請(qǐng)求的更新(步驟575);b)如果FE#x是直接參與切換的FE(即,已經(jīng)接收到SWITCHOVER_INITIATE(x)消息的FE)(步驟570)并且FE#x先前已經(jīng)向RP發(fā)送了FE_REPRPGRAM_COMPLETE(x)消息(步驟580),則FE#x立即執(zhí)行所請(qǐng)求的更新(步驟585);c)如果FE#x是直接參與切換的FE(即,已經(jīng)接收到SWITCHOVER_INITIATE(x)消息的FE)(步驟570)并且FE#x尚未發(fā)送FE_REPRPGRAM_COMPLETE(x)消息(例如,該FE是單配置組的成員,因此由于對(duì)硬件表實(shí)際上進(jìn)行重編程所花的時(shí)間,將花費(fèi)較長(zhǎng)的時(shí)間來(lái)切換)(步驟580),則FE#x只將SWITCHOVER_ADVERTISE(x,w)消息加入隊(duì)列(步驟590),用于隨后處理(在FE#x最終發(fā)送了其FE_REPRPGRAM_COMPLETE(x)消息之后)。
應(yīng)該注意,F(xiàn)E#x要進(jìn)行的更新通常包括如下幾項(xiàng)。首先,F(xiàn)E#x針對(duì)消息中所指示的FE參數(shù)(即,可能是FE#(w-1)或FE#(w+1)),將“交換結(jié)構(gòu)端口映射表”條目更新為FE#w。本質(zhì)上,當(dāng)FE參數(shù)是(w-1)時(shí),地址是FE#(w-1)的交換結(jié)構(gòu)端口的條目現(xiàn)在被更新為包括FE#w的交換結(jié)構(gòu)端口的值。其次,如果對(duì)任何FE#w,這是所處理的第一個(gè)SWITCHOVER_ADVERTISE(x,w)消息,則FE#x更新包括任何直接參與切換的FE的多播條目,就如消息的參數(shù)所指示的那樣。
9)當(dāng)FE#x完成SWITCHOVER_ADVERTISE(x,w)消息所請(qǐng)求的更新時(shí),該FE#x向RP回復(fù)ADVERTISE_COMPLETED(x,w)消息。作為示例,F(xiàn)E#7向RP發(fā)送ADVERTISE_COMPLETED(7,3)消息,指示該消息來(lái)自FE#7,并且由RP所請(qǐng)求的涉及FE#3的更新已經(jīng)完成。
10)對(duì)于RP從FE#w接收到的指示涉及FE#x的更新已經(jīng)完成的每個(gè)ADVERTISE_COMPLETE(w,x)消息(步驟555),RP向FE#x發(fā)送REMOVE_FLOW_CONTROL(x,w)消息(步驟560),請(qǐng)求去除FE#w的流控制。
11)當(dāng)FE#x接收到請(qǐng)求去除FE#w的流控制的REMOVE_FLOW_CONTROL(x,w)消息時(shí),F(xiàn)E#x去除向FE#w的強(qiáng)制單播和多播流控制(步驟565)。
結(jié)果,F(xiàn)E#x又開(kāi)始處理從FE#w去往FE#x的流量,并且當(dāng)每個(gè)其他FE完成其它們的切換時(shí)(如果它們是直接參與切換的FE的話),或者當(dāng)它們只更新其表中的條目時(shí)(如果它們是未直接參與切換的FE的話),在FE#x的出轉(zhuǎn)發(fā)引擎(OFE)上重新開(kāi)始處理來(lái)自這些FE的流量。
圖6圖示了RP和正在經(jīng)歷切換的單個(gè)FE之間的基本切換協(xié)議。如先前更詳細(xì)地描述一樣,RP首先向FE發(fā)送SWITCHOVER_INITIATE(x)消息600,以在FE中發(fā)起切換操作。一旦FE的重編程完成,則FE以FE_REPRPGRAM_COMPLETE(X)消息610做出響應(yīng)。然后RP發(fā)送出SWITCHOVER_ADVERTISE(X,X)消息620,以請(qǐng)求FE更新各種硬件配置信息。然后一旦FE完成RP所請(qǐng)求的更新,就發(fā)送ADVERTISE_COMPLETE(X,X)消息630。然后RP發(fā)送REMOVE_FLOW_CONTROL(X,X)消息640,以請(qǐng)求去除系統(tǒng)中該FE和其他FE之間的流控制。
應(yīng)該注意,當(dāng)機(jī)架中有多個(gè)FE時(shí),RP向所有FE發(fā)送“SWITCHOVER ADVERTISE”消息,最終請(qǐng)求來(lái)自每個(gè)FE的“ADVERTISE COMPLETE”響應(yīng)。一旦接收到“ADVERTISECOMPLETE”響應(yīng),RP就向剛完成切換的FE發(fā)送針對(duì)以“ADVERTISECOMPLETE”做出響應(yīng)的每個(gè)FE的“REMOVE FLOW CONTROL”消息。因此,為了示出基本的協(xié)議,該圖中刪去了與多個(gè)FE相關(guān)的大多數(shù)復(fù)雜度。
圖7圖示了RP和三個(gè)不同F(xiàn)E之間的交互作用,其中一個(gè)FE由于是單配置FE所以切換較慢(稱為FE#X),另一FE由于具有雙配置所以切換較快(稱為FE#Y),而另一個(gè)FE非參與FE(稱為FE#Z)。該圖有助于理解如何經(jīng)由“SWITCHOVER ADVERTISE”消息將每個(gè)切換傳送到其他FE。圖7還示出了“快速切換”FE在“慢速切換”FE完成其切換之前完成自身切換的方式。實(shí)際上,每個(gè)FE獨(dú)立于其他FE而進(jìn)行切換,而同時(shí)使其他FE得知其進(jìn)度。圖7中代表消息的每條線的圓點(diǎn)端表示該消息的發(fā)信方。圖7中代表消息的每條線的箭頭端表示該消息的接收方。
該過(guò)程開(kāi)始于RP向FE#X發(fā)送SWITCHOVER_INITIATE(X)消息700,并向FE#Y發(fā)送SWITCHOVER_INITIATE(Y)消息705。但是不向FE#Z發(fā)送這種消息,因?yàn)槠洳⒉粎⑴c該切換。一旦完成對(duì)入口相關(guān)的硬件表的重編程(對(duì)于FE#X,這要快于FE#Y完成),則FE#X以FE_REPRPGRAM_COMPLETE(X)消息710做出響應(yīng)。然后RP向FE#X發(fā)送SWITCHOVER_ADVERTISE(X,X)消息715,向FE#Y發(fā)送SWITCHOVER_ADVERTISE(Y,X)消息720,并向FE#Z發(fā)送SWITCHOVER_ADVERTISE(Z,X)消息725,以向這些FE通知FE#X已經(jīng)完成其切換。然后FE#X以ADVERTISE_COMPLETE(X,X)消息730做出應(yīng)答,指示FE#X已經(jīng)完成RP所要求的更新。然后FE#Z以ADVERTISE_COMPLETE(Z,X)消息735做出應(yīng)答,指示FE#Z也完成了RP所要求的更新。FE#X和FE#Z已經(jīng)完成了這些更新,則RP現(xiàn)在向FE#X發(fā)送REMOVE_FLOW_CONTROL(X,X)消息740,并向FE#Z發(fā)送REMOVE_FLOW_CONTROL(X,Z)消息745,以從FE#X和FE#Z去除到FE#X的流控制。
FE#Y現(xiàn)在響應(yīng)于RP已經(jīng)發(fā)送的SWITCHOVER_INITIATE(Y)消息705,向RP發(fā)送FE_REPRPGRAM_COMPLETE(Y)消息750,指示完成了對(duì)FE#Y的入口相關(guān)硬件表的重編程。FE#Y現(xiàn)在還響應(yīng)于RP發(fā)送的SWITCHOVER_ADVERTISE(Y,X)消息720,向RP發(fā)送ADVERTISE_COMPLETE(Y,X)消息755。RP以REMOVE_FLOW_CONTROL(X,Y)消息760響應(yīng)于該消息,指示FE#Y應(yīng)該去除對(duì)FE#X的流控制。RP還向FE#X發(fā)送SWITCHOVER_ADVERTISE(X,Y)消息765,向FE#Y發(fā)送SWITCHOVER_ADVERTISE(Y,Y)消息770,并向FE#Z發(fā)送SWITCHOVER_ADVERTISE(Z,Y)消息775,指示各個(gè)FE應(yīng)該執(zhí)行所請(qǐng)求的更新。FE#Y以ADVERTISE_COMPLETE(Y,Y)消息780做出響應(yīng),指示FE#Y已經(jīng)完成所請(qǐng)求的更新。然后RP以REMOVE_FLOW_CONTROL(Y,Y)消息785做出響應(yīng),以使FE#Y從其自身流去除流控制。FE#X現(xiàn)在以ADVERTISE_COMPLETE(X,Y)消息790響應(yīng)于RP發(fā)送的SWITCHOVER_ADVERTISE(X,Y)消息765。然后RP通過(guò)向FE#Y發(fā)送REMOVE_FLOW_CONTROL(Y,X)消息792,來(lái)指示FE#Y應(yīng)該去除流控制。FE#Z現(xiàn)在通過(guò)向RP發(fā)送ADVERTISE_COMPLETE(Z,Y)消息794,以響應(yīng)RP發(fā)送的SWITCHOVER_ADVERTISE(Z,Y)消息775。RP通過(guò)向FE#Y發(fā)送REMOVE_FLOW_CONTROL(Y,Z)796消息做出響應(yīng),以去除流控制。
根據(jù)本發(fā)明的方法和系統(tǒng)提供了眾多優(yōu)點(diǎn)。使用這種方法和系統(tǒng)的網(wǎng)絡(luò)元件體系結(jié)構(gòu)在FE發(fā)生故障時(shí)能迅速、高效地恢復(fù)服務(wù)。這種“基于個(gè)體的切換”技術(shù)通過(guò)單獨(dú)處理每個(gè)轉(zhuǎn)發(fā)引擎,對(duì)適當(dāng)信息的復(fù)制一完成就執(zhí)行切換并使網(wǎng)絡(luò)元件恢復(fù)服務(wù),而不需要等待一組轉(zhuǎn)發(fā)引擎完成其各自的切換,獲得了這種優(yōu)點(diǎn)。這種基于個(gè)體的切換技術(shù)還可以將入路徑的切換與出路徑的切換相分離。這種方法允許給定轉(zhuǎn)發(fā)引擎的入轉(zhuǎn)發(fā)路徑恢復(fù)服務(wù),而該轉(zhuǎn)發(fā)引擎的出路徑還在經(jīng)歷切換。這允許轉(zhuǎn)發(fā)引擎的入路徑向其他轉(zhuǎn)發(fā)引擎(它們的出路徑已經(jīng)完成切換,或者它們沒(méi)有參與切換)轉(zhuǎn)發(fā)分組,從而減少了恢復(fù)服務(wù)的時(shí)間。
雖然示出并描述了本發(fā)明的具體實(shí)施例,但是本領(lǐng)域的技術(shù)人員應(yīng)該清楚,基于這里的教導(dǎo),可以做出改變和修改,而不脫離本發(fā)明及其更廣的方面,因此,所附權(quán)利要求是要在其范圍之內(nèi)包括處于本發(fā)明的真正精神和范圍之內(nèi)的所有這些改變和修改。另外,還應(yīng)理解,本發(fā)明只由所附權(quán)利要求規(guī)定。
權(quán)利要求
1.一種方法,包括接收轉(zhuǎn)發(fā)引擎應(yīng)該執(zhí)行切換操作的指示;和響應(yīng)于所述接收所述指示的步驟,執(zhí)行所述切換操作,其中所述切換操作包括在第一接口卡和第二接口卡之間切換所述轉(zhuǎn)發(fā)引擎的耦合,獨(dú)立于另一切換操作執(zhí)行所述切換操作,并且由另一轉(zhuǎn)發(fā)引擎執(zhí)行所述另一切換操作。
2.如權(quán)利要求1所述的方法,其中所述執(zhí)行所述切換操作的步驟包括重編程所述轉(zhuǎn)發(fā)引擎的入口路徑;和重編程所述轉(zhuǎn)發(fā)引擎的出口路徑。
3.如權(quán)利要求2所述的方法,其中所述對(duì)所述轉(zhuǎn)發(fā)引擎的所述入口路徑進(jìn)行重編程的步驟與所述對(duì)所述轉(zhuǎn)發(fā)引擎的所述出口路徑進(jìn)行重編程的步驟彼此獨(dú)立。
4.如權(quán)利要求1所述的方法,還包括指示所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
5.如權(quán)利要求4所述的方法,還包括接收所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示;和對(duì)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示作出確認(rèn)。
6.如權(quán)利要求5所述的方法,其中所述轉(zhuǎn)發(fā)引擎是多個(gè)轉(zhuǎn)發(fā)引擎之一,并且每個(gè)所述轉(zhuǎn)發(fā)引擎都接收所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示。
7.如權(quán)利要求6所述的方法,還包括確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
8.如權(quán)利要求4所述的方法,還包括確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
9.如權(quán)利要求8所述的方法,還包括去除所述轉(zhuǎn)發(fā)引擎和執(zhí)行所述確認(rèn)的轉(zhuǎn)發(fā)引擎之間的流控制。
10.如權(quán)利要求9所述的方法,其中,只在執(zhí)行所述確認(rèn)的所述轉(zhuǎn)發(fā)引擎執(zhí)行所述確認(rèn)之后,才執(zhí)行所述去除所述流控制的步驟。
11.一種計(jì)算機(jī)程序產(chǎn)品,包括可在計(jì)算機(jī)系統(tǒng)上執(zhí)行的第一組指令,被配置為接收所述轉(zhuǎn)發(fā)引擎應(yīng)該執(zhí)行切換操作的指示;可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第二組指令,被配置為響應(yīng)于所述指示來(lái)執(zhí)行所述切換操作,其中被配置為使所述處理器執(zhí)行所述切換操作的所述計(jì)算機(jī)代碼還被配置為在第一接口卡和第二接口卡之間切換所述轉(zhuǎn)發(fā)引擎的耦合,獨(dú)立于另一切換操作執(zhí)行所述切換操作,并且由另一轉(zhuǎn)發(fā)引擎執(zhí)行所述另一切換操作;以及計(jì)算機(jī)可讀介質(zhì),其中所述計(jì)算機(jī)程序產(chǎn)品被編碼在所述計(jì)算機(jī)可讀介質(zhì)中。
12.如權(quán)利要求11所述的計(jì)算機(jī)程序產(chǎn)品,其中所述第二組指令包括可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第一子集指令,被配置為重編程所述轉(zhuǎn)發(fā)引擎的入口路徑;和可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第二子集指令,被配置為重編程所述轉(zhuǎn)發(fā)引擎的出口路徑。
13.如權(quán)利要求12所述的計(jì)算機(jī)程序產(chǎn)品,其中所述入口路徑和所述出口路徑被配置為彼此獨(dú)立地被重編程。
14.如權(quán)利要求11所述的計(jì)算機(jī)程序產(chǎn)品,還包括可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第三組指令,被配置為其中所述入口路徑和所述出口路徑被配置為彼此獨(dú)立地被重編程。
15.如權(quán)利要求14所述的計(jì)算機(jī)程序產(chǎn)品,還包括可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第四組指令,被配置為接收所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示;和可在所述計(jì)算機(jī)系統(tǒng)上執(zhí)行的第五組指令,被配置為對(duì)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示作出確認(rèn)。
16.一種設(shè)備,包括用于接收轉(zhuǎn)發(fā)引擎應(yīng)該執(zhí)行切換操作的指示的裝置;和用于執(zhí)行所述切換操作的裝置,其中用于執(zhí)行所述切換操作的所述裝置耦合到用于接收所述指示的所述裝置,所述切換操作包括在第一接口卡和第二接口卡之間切換所述轉(zhuǎn)發(fā)引擎的耦合,獨(dú)立于另一切換操作執(zhí)行所述切換操作,并且由另一轉(zhuǎn)發(fā)引擎執(zhí)行所述另一切換操作。
17.如權(quán)利要求16所述的設(shè)備,其中所述轉(zhuǎn)發(fā)引擎包括入口路徑和出口路徑,并且用于執(zhí)行所述切換操作的所述裝置包括用于重編程所述入口路徑的裝置;和用于重編程所述出口路徑的裝置。
18.如權(quán)利要求17所述的設(shè)備,其中用于重編程所述入口路徑的所述裝置和用于重編程所述出口路徑的所述裝置彼此獨(dú)立工作。
19.如權(quán)利要求16所述的設(shè)備,還包括用于指示所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的裝置。
20.如權(quán)利要求19所述的設(shè)備,還包括用于接收所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示的裝置;和用于對(duì)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示作出確認(rèn)的裝置。
21.如權(quán)利要求20所述的設(shè)備,其中所述轉(zhuǎn)發(fā)引擎是多個(gè)轉(zhuǎn)發(fā)引擎之一,并且每個(gè)所述轉(zhuǎn)發(fā)引擎都被配置為接收所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示。
22.如權(quán)利要求19所述的設(shè)備,還包括用于確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的裝置。
23.一種方法,包括接收轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作的指示,其中在多個(gè)轉(zhuǎn)發(fā)引擎之一處接收所述指示,并且所述多個(gè)轉(zhuǎn)發(fā)引擎包括所述轉(zhuǎn)發(fā)引擎;和響應(yīng)于接收到所述指示的所述接收步驟,使所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)所述指示,其中所述指示指出所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
24.如權(quán)利要求23所述的方法,還包括去除所述轉(zhuǎn)發(fā)引擎和所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎之間的流控制。
25.如權(quán)利要求24所述的方法,其中所述去除所述流控制的步驟包括接收所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的指示;和響應(yīng)于所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的所述指示,使所述轉(zhuǎn)發(fā)引擎去除所述流控制。
26.如權(quán)利要求25所述的方法,其中所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的所述指示是接收到去除流控制消息。
27.如權(quán)利要求24所述的方法,其中只在所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎對(duì)接收到所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指示的所述接收作出確認(rèn)之后,才執(zhí)行所述去除所述流控制的步驟。
28.一種設(shè)備,包括用于接收轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作的指示的裝置,其中在多個(gè)轉(zhuǎn)發(fā)引擎之一處接收所述指示,并且所述多個(gè)轉(zhuǎn)發(fā)引擎包括所述轉(zhuǎn)發(fā)引擎;和用于響應(yīng)于接收到所述指示的所述接收步驟,使所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)所述指示的裝置,其中所述指示指出所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
29.如權(quán)利要求28所述的設(shè)備,還包括用于去除所述轉(zhuǎn)發(fā)引擎和所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎之間的流控制的裝置。
30.如權(quán)利要求29所述的設(shè)備,其中所述去除所述流控制的步驟包括用于接收所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的指示的裝置;和用于響應(yīng)于所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的所述指示,使所述轉(zhuǎn)發(fā)引擎去除所述流控制的裝置。
31.如權(quán)利要求30所述的設(shè)備,其中所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制的所述指示是接收到去除流控制消息。
32.如權(quán)利要求29所述的設(shè)備,其中只在所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述一個(gè)轉(zhuǎn)發(fā)引擎對(duì)接收到所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作的所述指令的所述接收作出確認(rèn)之后,所述用于去除流控制的裝置才去除所述流控制。
33.一種網(wǎng)絡(luò)元件中的故障恢復(fù)方法,所述方法包括向多個(gè)轉(zhuǎn)發(fā)引擎指示轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作;和響應(yīng)于所述指示,使所述多個(gè)轉(zhuǎn)發(fā)引擎中的至少一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
34.如權(quán)利要求33所述的方法,其中所述指示步驟包括從路由處理器向所述轉(zhuǎn)發(fā)引擎發(fā)送第一消息,其中所述網(wǎng)絡(luò)元件包括通信耦合到所述轉(zhuǎn)發(fā)引擎的所述路由處理器,并且所述第一消息指示所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作;和所述使確認(rèn)的步驟包括從所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述至少一個(gè)轉(zhuǎn)發(fā)引擎向所述路由處理器發(fā)送第二消息,其中所述第二消息指示所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述至少一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
35.如權(quán)利要求34所述的方法,其中所述第一消息是切換廣告消息。
36.如權(quán)利要求35所述的方法,其中所述第二消息是廣告完成消息。
37.如權(quán)利要求34所述的方法,其中所述轉(zhuǎn)發(fā)引擎是所述多個(gè)轉(zhuǎn)發(fā)引擎之一。
38.如權(quán)利要求34所述的方法,還包括使所述轉(zhuǎn)發(fā)引擎執(zhí)行所述切換操作。
39.如權(quán)利要求38所述的方法,其中所述使所述轉(zhuǎn)發(fā)引擎執(zhí)行所述切換操作的步驟包括從所述路由處理器向所述轉(zhuǎn)發(fā)引擎發(fā)送第三消息,其中所述第三消息指示所述轉(zhuǎn)發(fā)引擎應(yīng)該執(zhí)行所述切換操作;和響應(yīng)于所述第一消息使所述轉(zhuǎn)發(fā)引擎執(zhí)行所述切換操作。
40.如權(quán)利要求39所述的方法,其中所述第三消息是切換發(fā)起消息。
41.如權(quán)利要求39所述的方法,其中所述使所述轉(zhuǎn)發(fā)引擎執(zhí)行所述切換操作的步驟還包括從所述轉(zhuǎn)發(fā)引擎向所述路由處理器發(fā)送第四消息,其中所述第四消息向所述路由處理器指示所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作。
42.如權(quán)利要求41所述的方法,其中所述第四消息是FE重編程完成消息。
43.如權(quán)利要求38所述的方法,其中所述切換操作包括重編程所述轉(zhuǎn)發(fā)引擎。
44.如權(quán)利要求43所述的方法,其中所述重編程所述轉(zhuǎn)發(fā)引擎的步驟包括重編程所述轉(zhuǎn)發(fā)引擎的入口路徑;和重編程所述轉(zhuǎn)發(fā)引擎的出口路徑。
45.如權(quán)利要求34所述的方法,還包括去除所述轉(zhuǎn)發(fā)引擎和所述多個(gè)轉(zhuǎn)發(fā)引擎中至少一個(gè)轉(zhuǎn)發(fā)引擎之間的流控制。
46.如權(quán)利要求45所述的方法,其中所述去除所述流控制的步驟包括從所述路由處理器向所述轉(zhuǎn)發(fā)引擎發(fā)送第五消息,其中所述第五消息指示所述轉(zhuǎn)發(fā)引擎應(yīng)該去除所述流控制;和響應(yīng)于所述第五消息,使所述轉(zhuǎn)發(fā)引擎去除所述流控制。
47.如權(quán)利要求46所述的方法,其中所述第五消息是去除流控制消息。
48.如權(quán)利要求45所述的方法,其中只在所述多個(gè)轉(zhuǎn)發(fā)引擎中的所述至少一個(gè)轉(zhuǎn)發(fā)引擎確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成所述切換操作之后,才執(zhí)行所述去除流控制的步驟。
49.一種轉(zhuǎn)發(fā)引擎,包括入口路徑;出口路徑;和控制器,其中所述入口路徑和所述出口路徑彼此獨(dú)立,并且所述控制器被耦合以獨(dú)立地控制所述入口路徑和所述出口路徑。
50.如權(quán)利要求49所述的轉(zhuǎn)發(fā)引擎,其中所述轉(zhuǎn)發(fā)引擎能夠擔(dān)當(dāng)主轉(zhuǎn)發(fā)引擎和備用轉(zhuǎn)發(fā)引擎之一。
51.如權(quán)利要求49所述的轉(zhuǎn)發(fā)引擎,其中所述入口路徑包括入站處理元件,并且所述出口路徑包括出站處理元件。
52.如權(quán)利要求51所述的轉(zhuǎn)發(fā)引擎,其中所述入口路徑還包括耦合到所述入站處理元件的入站選擇器,并且所述出口路徑還包括耦合到所述出站處理元件的出站選擇器。
53.如權(quán)利要求52所述的轉(zhuǎn)發(fā)引擎,其中所述入站選擇器被配置為將所述入站處理元件耦合到第一接口單元和第二接口單元之一,并且所述出站選擇器被配置為將所述出站處理元件耦合到所述第一接口單元和所述第二接口單元之一。
54.如權(quán)利要求51所述的轉(zhuǎn)發(fā)引擎,其中所述入站處理元件包括第一緩存存儲(chǔ)器,并且所述出站處理元件包括第二緩存存儲(chǔ)器。
55.如權(quán)利要求54所述的轉(zhuǎn)發(fā)引擎,其中所述轉(zhuǎn)發(fā)引擎被配置為將第一配置信息存儲(chǔ)在所述第一緩存中,并將第二配置信息存儲(chǔ)在所述第二緩存中,并且所述第一配置信息和所述第二配置信息代表所述轉(zhuǎn)發(fā)引擎的第一配置。
56.如權(quán)利要求55所述的轉(zhuǎn)發(fā)引擎,其中所述轉(zhuǎn)發(fā)引擎還被配置為將第三配置信息存儲(chǔ)在所述第一緩存中,并將第四配置信息存儲(chǔ)在所述第二緩存中,并且所述第三配置信息和所述第四配置信息代表所述轉(zhuǎn)發(fā)引擎的第二配置。
57.如權(quán)利要求56所述的轉(zhuǎn)發(fā)引擎,其中所述轉(zhuǎn)發(fā)引擎通過(guò)被配置為使用存儲(chǔ)在所述第一緩存中的所述第三配置信息并使用存儲(chǔ)在所述第二緩存中的所述第四配置信息,被配置為在所述轉(zhuǎn)發(fā)引擎的所述第一配置和所述轉(zhuǎn)發(fā)引擎的所述第二配置之間切換。
58.如權(quán)利要求55所述的轉(zhuǎn)發(fā)引擎,還包括耦合到所述控制器的存儲(chǔ)器。
59.如權(quán)利要求58所述的轉(zhuǎn)發(fā)引擎,其中所述控制器被配置為在所述存儲(chǔ)器中存儲(chǔ)第三配置信息和第四配置信息,并且所述第三配置信息和所述第三配置信息代表所述轉(zhuǎn)發(fā)引擎的第二配置。
60.如權(quán)利要求59所述的轉(zhuǎn)發(fā)引擎,其中所述轉(zhuǎn)發(fā)引擎通過(guò)被配置為從所述存儲(chǔ)器將所述第三配置信息復(fù)制到所述第一緩存并從所述存儲(chǔ)器將所述第四配置信息復(fù)制到所述第二緩存,被配置為在所述轉(zhuǎn)發(fā)引擎的所述第一配置和所述轉(zhuǎn)發(fā)引擎的所述第二配置之間切換。
全文摘要
本發(fā)明公開(kāi)了一種網(wǎng)絡(luò)元件(100)中的故障恢復(fù)方法。該方法包括向眾多轉(zhuǎn)發(fā)引擎(120(1)~(N+1))指示某一轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作,并響應(yīng)于該指示,使這多個(gè)轉(zhuǎn)發(fā)引擎(120(1)~(N+1))中至少一個(gè)確認(rèn)所述轉(zhuǎn)發(fā)引擎已經(jīng)完成切換操作。
文檔編號(hào)H04L1/22GK1706160SQ200480001237
公開(kāi)日2005年12月7日 申請(qǐng)日期2004年1月11日 優(yōu)先權(quán)日2003年1月13日
發(fā)明者馬庫(kù)斯·A·馬蘭奧, 邁克爾·羅伊·史密斯, 約翰·M·奈特, 魯希特·什里瓦斯塔瓦, 安娜·H·布爾蓋萊亞 申請(qǐng)人:思科技術(shù)公司
網(wǎng)友詢問(wèn)留言 已有0條留言
  • 還沒(méi)有人留言評(píng)論。精彩留言會(huì)獲得點(diǎn)贊!
1
崇明县| 邢台县| 江华| 佛冈县| 尉犁县| 资阳市| 宁化县| 白玉县| 浦城县| 抚州市| 昌宁县| 辽源市| 三门峡市| 乐东| 稷山县| 东兰县| 定安县| 万山特区| 大港区| 汤原县| 阳春市| 察雅县| 社旗县| 淳化县| 赤峰市| 临武县| 拉萨市| 大名县| 盱眙县| 高邮市| 故城县| 布尔津县| 响水县| 弥渡县| 大名县| 巴东县| 通渭县| 大埔县| 武定县| 南丰县| 咸丰县|