JP2004517519A - 高速インターネットプロトコルルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための装置及び方法 - Google Patents

高速インターネットプロトコルルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための装置及び方法 Download PDF

Info

Publication number
JP2004517519A
JP2004517519A JP2002553673A JP2002553673A JP2004517519A JP 2004517519 A JP2004517519 A JP 2004517519A JP 2002553673 A JP2002553673 A JP 2002553673A JP 2002553673 A JP2002553673 A JP 2002553673A JP 2004517519 A JP2004517519 A JP 2004517519A
Authority
JP
Japan
Prior art keywords
prefix length
node
prefix
route
hash table
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2002553673A
Other languages
English (en)
Other versions
JP3790217B2 (ja
Inventor
ミョンス チョ
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Samsung Electronics Co Ltd
Original Assignee
Samsung Electronics Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from KR10-2001-0007568A external-priority patent/KR100493099B1/ko
Application filed by Samsung Electronics Co Ltd filed Critical Samsung Electronics Co Ltd
Publication of JP2004517519A publication Critical patent/JP2004517519A/ja
Application granted granted Critical
Publication of JP3790217B2 publication Critical patent/JP3790217B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/742Route cache; Operation thereof
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/745Address table lookup; Address filtering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/74Address processing for routing
    • H04L45/745Address table lookup; Address filtering
    • H04L45/74591Address table lookup; Address filtering using content-addressable memories [CAM]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/22Parsing or analysis of headers

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

スキップリストを利用してIPアドレス検索のためのルーティング/フォワーディングテーブルを構築する方法を提供する。その方法は、インターネットプロトコルアドレスのプレフィックス長さ範囲を予め設定された方式によって分割する過程と、プレフィックス長さ範囲の分割されたクラスターの個数に基づいた最大レベルを有し、スキップリスト内の全てのノードをポインティングするためのヘッダノードを生成する過程と、それぞれ前記分割されたプレフィックス長さ範囲をキーとして有し、前記分割されたクラスターの個数の分だけサブノードを生成する過程と、から構成される。

Description

【0001】
【発明の属する技術分野】
本発明は、インターネット上においてパケットを目的地に伝送するためのルーティング(routing)技術に関し、特に、高速にインターネットプロトコル(Internet Protocol: 以下、IPと称する)ルートルックアップ(route lookup)を遂行し、ルーティング(または、フォワーディング)テーブルを管理する装置及び方法に関する。
【0002】
【従来の技術】
現在、インターネット利用者の急増、提供されるサービスの多様化、及びVoIP(Voice over Internet Protocol)などの利用分野の拡大によって、インターネットのトラヒックが急激に増加している。ギガ(Giga)またはテラ(Tera)級の高速ルータ(router)において、遅延なしで目的経路を発見することによってパケットを次のホップインターフェース(hop interface)に伝送することが技術的な懸案になっている。前記ルータの物理的入力インターフェースを通して伝達されるパケットの目的地経路を発見するために、最短経路のルーティング(または、フォワーディング)テーブルの維持及び検索時間の短縮が要求される。
【0003】
従来のルータにおいて、パケットを処理し、該パケットの目的地を検索するために要する時間が伝送路を通して到達されるパケットの伝送時間に比べて高速であるので、サブネットワークまたは他のネットワークを連結する接続ノードとしてのルータの機能の遂行には問題がなかった。最近、POS OC−192(10Gbps)またはIP over DWDM(Dense Wavelength Division Multiplexing)などの光ネットワークインターフェースの帯域幅が増加し、それとともに、パケットの伝送時間がルータにおける処理時間より相対的に短くなり、さらに、この帯域幅の増加は、ルータが高速インターネット上でボトルネック(bottleneck)の主要原因を提供するという非難を招いた。前記のような技術としては、Keshav, S. and Sharma, R., Issues and Trends in Router Design, IEEE Communications Magazine, pages 144−151,May,1998、Kumar, V. and Lakshman, T. and Stiliadis, D., Beyond Best Effort: Router Architectures for the Differentiated Services of Tomorrow’s Internet, IEEE Communications Magazine, pages 152−164,May,1998、Chan, H., Alnuweiri, H. and Leung, V., A Framework for Optimizing the Cost and Performance of Next−Generation IP Routers, IEEE Journal of Selected Areas in Communications, Vol. 17, No.6, pages 1013−1029, June 1999、Partridge, C. et al., A 50−Gb/s IP Router, IEEE/ACM Trans. on Networking, vol. 6, no.3, pages 237−248, 1998、及びMetz, C., IP Routers: New Tool for Gigabit Networking, IEEE Internet Computing, pages 14−18, Nov.−Dec.,1998.に開示されている。
【0004】
1990年代初めに、インターネットの技術標準を管理するIETF(Internet Engineering Task Force)のワーキンググループ(working group)は、IPv4(IP version 4)におけるIPアドレスを効率的に使用するCIDR(Classless Inter−Domain Routing)という新しいIPアドレシング方式を導入した。これは、RFC(Request for Comments : Network Working Group) 1518, An Architecture for IP Address Allocation with CIDR, Sept. 1993及びRFC 1517, Applicability Statement for the Implementation of Classless Inter−Domain Routing (CIDR), Sept. 1993.に開示されている。
【0005】
この場合、多様なプレフィックス(prefix)長さを有するパケットにおいて対応するプレフィックスを把握し、最長プレフィックス(longest prefix)に一致(matching)するIPアドレスを発見するために、一般的に、トライ(trie)またはパトリシア(Patricia: Practical Algorithm to Retrieve Information Coded as Alphanumeric)トライデータ構造に基づいたLPM(Longest Prefix Matching)アルゴリズムが使用されてきた。これは、Doeringer, W., Karjoth, G. and Nassehi, M., Routing on Longest−Matching Prefixes, IEEE/ACM Trans. on Networking, vol.4, no.1, pages 86−97, Feb., 1996.に開示されている。
【0006】
以下、表1を参照して前記LMPアルゴリズムを詳細に説明する。表1は、ルーティング(または、フォワーディング)テーブルに含まれるルーティングエントリの簡単な例を示す。IPv4の場合に、実は前記プレフィックスが32を超過することはできないが、表1における星印は、‘0’または‘1’からなる任意の数を詰めることを可能にする。例えば、‘0*’は、‘01*’、‘011*’、または‘010*’を含み、残りのビットストリング(bit string)がどういうものなのかは問題にならない。
【表1】
Figure 2004517519
【0007】
ルーティングエントリまたはルートは、{<network prefix>,<host number>}からなるIPアドレスによって表現される。目的地IPアドレスが‘10010101000…0’である場合、この目的地IPアドレスの1番目のビットは、前記ルーティングテーブルに含まれるネットワークプレフィックス(以下、簡単にプレフィックスと称する)と比較される。従って、‘0*’、‘01010*’、‘010101*’、及び‘0101011*’などのプレフィックスは、自分の1番目のビットが‘0’から始まるので、除かれる。所定の目的地アドレスを残りのプレフィックスと比較する場合、プレフィックス‘11*’、‘1110*’、及び‘1001010101*’は、前記目的地アドレスと2番目のビットまたは10番目のビットで一致しないので、除かれる。次に、残りの対象プレフィックス(つまり、‘1*’、‘10*’、及び‘100101010*’)のうち、‘100101010*’が前記最長プレフィックス(または、most specific)一致ルートとして選択され、当該目的地IPアドレスを有するIPパケットは、インターフェース‘10’を通して隣接ルータに伝送される。
【0008】
一方、最近発表された経路検索(routing lookup)アルゴリズムは、メモリアクセス時間を短縮するために、使用できるプロセッサ(ルーティングプロセッサまたはフォワーディングエンジン)内のキャッシュメモリ(cache memory)に貯蔵される。このルーティングテーブルに基づいた経路検索アルゴリズムは、効率的な検索を支援するが、ルーティングテーブルまたはフォーワーディングテーブルを変更することはできない。従って、この経路検索アルゴリズムは、変更されたルートの反映による遅延時間を生じさせる可能性がある。
【0009】
さらに、ルーティングプロセッサにおけるルーティングテーブルは、DMA(Direct Memory Access)カード、IPC(Inter−Processor Communication)カード、またはスイッチファブリックを通してコピーされて、フォワーディングエンジンにおけるフォワーディングテーブルに適用される。この時、変更されたルートのみを追加及び削除するのではなく、新しいフォワーディングテーブルを構築する必要がある。これは、追加的な時間遅延を生じさせ、さらに、ルータからのメモリアクセス要求によるメモリ帯域幅使用の増加によって、ルータの内部メモリまたはシステムバス(system bus)におけるボトルネックを生じさせる可能性がある。
【0010】
さらに、一部のアルゴリズムにおいて、最初のルーティングテーブル(または、フォワーディングテーブル)は、ルータの現在のリンク状態を示す“リンク情報(link reachability information)”を使用して構成されるべきである。従って、リンク情報を順にルーティングテーブルに挿入するためには、前もってプレフィックス長さ別に全てのルートを分類(sorting)する追加的な作業が必要である。このようなアルゴリズムの例としては、Degermark, M., Brodnik, A., Carlsson, S. and Pink, S., Small Forwarding Tables for Fast Routing Lookups, In Proceedings of ACM SIGCOMM ’97, pages 3−14, Cannes, France, 1997、Srinivasan, V. and Varghese, G., Faster IP Lookups using Controlled Prefix Expansion, In Proceedings of ACM Sigmetrics ’98 Conf., pages 1−11, 1998、Lampson, B., Srinivasan, V. and Varghese, G., IP Lookups using Multiway and Multicolumn Search, In IEEE Infocom, pages 1248−1256, 1998、Tzeng, H. and Pryzygienda, T., On Fast Address−Lookup Algorithms, IEEE Journal on Selected Areas in Communications, Vol. 17, No. 6, pages 1067−1082, June, 1999、Waldvogel, M., Varghese, G., Turner, J. and Plattner, B., Scalable High Speed IP Routing Lookups, In Proceedings of ACM SIGCOMM ’97, Cannes, France, pages 25−37, 1997、及びWaldvogel, M., Varghese, G., Turner, J. and Plattner, B., Scalable Best Matching Prefix Lookups, In Proceedings of PODC ’98, Puerto Vallarta, page, 1998.がある。
【0011】
ルーティングテーブルにおいて代表的に使用されるデータ構造である“radix tree”または“Patricia trie”は、パケット経路を探すために要求されるメモリアクセスの数が増加するだけでなく、該当ルータの隣接ルータからルートを設定または削除することによって発生するルート変更を反映するためには、かなりの更新時間が要求される。Degermark, M., Brodnik, A., Carlsson, S. and Pink, S., Small Forwarding Tables for Fast Routing Lookups, In Proceedings of ACM SIGCOMM ’97, pages 3−14, Cannes, France, 1997には、フォーワーディングエンジンにおいてキャッシュに貯蔵できるコンパクト(compact)フォーワーディングテーブルが提示されているが、該当テーブルのルート変更を反映することは大変である。Srinivasan, V. and Varghese, G., Faster IP Lookups using Controlled Prefix Expansion, In Proceedings of ACM Sigmetrics ’98 Conf., pages 1−11, 1998によって提示された“controlled prefix expansion”方式(U.S. Patent No. 6,011,795, issued to George Varghese and Srinivasan and entitled Method and Apparatus for Fast Hierarchical Address Lookup Using Controlled Expansion of Prefixes)及びTzeng, H. and Pryzygienda, T., On Fast Address−Lookup Algorithms, IEEE Journal on Selected Areas in Communications, Vol. 17, No. 6, pages 1067−1082, June, 1999によって提示された高速(fast)アドレス検索アルゴリズムも“multi−resolution trie”に基づいているが、そのデータ構造は前記トライ(trie)に基づいているので、ルートの追加及び削除が容易でない。これに関連して、米国特許番号第6,061,712(Method for IP Routing Table Look−up)及び米国特許番号第6,067,574(High Speed Routing Using Compressed Tree Process)が、Hong−Yi Tzengに許与されている。ハッシュテーブルを使用してトライ構造を2進検索ツリー(binary tree)にマッピングすることによる“rope search”アルゴリズム(Waldvogel, M., Varghese, G., Turner, J. and Plattner, B., Scalable High Speed IP Routing Lookups, In Proceedings of ACM SIGCOMM ’97, Cannes, France, pages 25−37, 1997及びWaldvogel, M., Varghese, G., Turner, J. and Plattner, B., Scalable Best Matching Prefix Lookups, In Proceedings of PODC ’98, Puerto Vallarta, page, 1998)及び(Tzeng, H. and Pryzygienda, T., On Fast Address−Lookup Algorithms, IEEE Journal on Selected Areas in Communications, Vol. 17, No. 6, pages 1067−1082, June, 1999)による“multi−resolution trie”に基づいたコンプリート(complete)プレフィックストライは、それぞれのデータ構造が前記トライに基づいているので、変更されたルートエントリの更新によって非効率的になる傾向がある。これに関連して、米国特許番号第6,018,524(Scalable High Speed IP Routing Lookups)がJonathan Turner、George Varghese、及びMarcel Waldvogelに許与されている。
【0012】
これら以外にも、前記トライの他の変形が提示されている。例えば、検索時間を減少させるために2つのトライ(trie)を連結する“two−trie”方式(Kijkanjanarat, T. and Chao, H., Fast IP Lookups Using a Two−trie Data Structure, In Proceedings of Globecom’99, 1999)及びトライのレベル長さを短縮させるための“LC−tries”(Nillson, S. and Karlsoson, G., IP−Addresses Lookup Using LC−Tries, IEEE Journal on Selected Areas in Communications, Vol.17, No. 16, pages 1083−1092, 1999)、及び“DP−tries”(Doeringer, W., Karjoth, G. and Nassehi, M., Routing on Longest−Matching Prefixes, IEEE/ACM Trans. on Networking, vol.4, no.1, pages 86−97, Feb., 1996)も提案されている。しかしながら、ルーティングテーブル(または、フォワーディングテーブル)のルート変更の反映は依然として難しい。
【0013】
さらに、検索時間を低減するために前述したような方式が提案されたが、ルート更新に関する問題は依然として存在する。検索時間を低減するための方法として、ハードウェア的に処理するための方法も提案されている。Gupta, P., Lin, S. and McKeown, N., Routing Lookups in Hardware at Memory Access Speeds, In Proceedings of IEEE INFOCOM ’98 Conf., pages 1240−1247, 1998に開示したように、大容量のメモリの使用による方法が提示された。この方式は、ソフトウェア的な方法に比べて検索時間は短縮されるが、IPv6(Internet Protocol version 6)に遷移する時は、メモリの容量またはコストなどの問題が依然として発生する。McAuley, A. and Francis, P., Fast Routing Table Lookup Using CAMs, In Proceedings of IEEE INFOCOM ’93, Vol.3, pages 1382−1391, 1993によってCAM(Content Addressable Memory)を使用する方法が提案されたが、CAMの高い値段のため、現在は考慮していない。Huang, N. and Zhao, S., A Novel IP−Routing Lookup Scheme and Hardware Architecture for Multigigabit Switching Routers, IEEE Journal on Selected Areas in Communications, Vol. 17, No. 6, pages 1093−1104, June, 1999は、メモリアクセスを低減するためにパイプライン(pipeline)式のメモリを使用する“indirect lookup”アルゴリズムを提示しているが、これもIPv6への適用は困難である。
【0014】
【発明が解決しようとする課題】
従って、本発明の目的は、無作為抽出(randomized)アルゴリズムを使用してメモリアクセス時間を最小にすることができることによって、費用効率の高いメモリ使用を可能にする高速IPルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための方法を提供することにある。
【0015】
本発明の他の目的は、ルートの追加及び削除に対する変更及び管理が容易にできる高速IPルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための方法を提供することにある。
【0016】
本発明のまた他の目的は、テーブルを構成する時、入力しようとするルートのプレフィックス長さによって関連ルートを分類(sorting)せずに、ルーティングテーブル/フォワーディングテーブルを効率的に構築することのできる高速IPルータルックアップ遂行及びルーティング/フォワーディングテーブル管理のための方法を提供することにある。
【0017】
【課題を解決するための手段】
このような目的を達成するための本発明の第1特徴によると、本発明は、所定の最大の値のキーを有するヘッダノード、及び減少される順で予め設定される固定的な(可変的な)範囲のキーを有し、それぞれのプレフィックス長さに関連したハッシュテーブルにそれぞれのプレフィックス長さに対応するルートエントリを貯蔵する複数のノードを含むスキップリストを使用して、キーとしてプレフィックス長さ範囲を有するIPアドレス検索方法を提供する。
【0018】
本発明の第2特徴によると、本発明は、前記スキップリスト内の全てのノードを取り扱うために最大レベルを有するヘッダノードを生成する過程と、前記スキップリストにプレフィックス範囲をキーとして有する複数のサブノードを挿入する過程と、それぞれのサブノードにおいて、プレフィックス範囲に対応する各ノードで与えられたルートエントリを貯蔵するためのハッシュテーブルを生成する過程と、からなるスキップリストを利用するIPルーティングテーブル生成方法を提供する。
【0019】
本発明の第3特徴によると、本発明は、IPアドレスのプレフィックス長さ範囲によって生成されたそれぞれのノードで設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用したルーティング/フォワーディングテーブルの更新方法を提供する。この方法は、更新されるルートのプレフィックス長さに対応するプレフィックス範囲が設定されたノードを見つける過程と、前記見つけたノードで前記更新されるルートと同一のプレフィックス長さを有するハッシュテーブルを検索する過程と、前記ハッシュテーブルを発見した時、前記ハッシュテーブルにおいて該当ルートを更新する過程と、からなる。
【0020】
本発明の第4特徴によると、本発明は、IPアドレスのプレフィックス範囲の割り当てによって生成されるそれぞれのノードで予め設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用するルーティング/フォワーディングテーブルのルートルックアップ方法を提供する。この方法は、前記スキップリストの第1ノードから始まって隣接したノードを見つける過程と、該当ノードで目的地アドレスとそれぞれのハッシュテーブルを比較する過程と、前記ハッシュテーブルが前記目的地アドレスを含む場合、一致するプレフィックスを最長プレフィックスとみなす過程と、からなる。
【0021】
【発明の実施の形態】
以下、本発明に従う好適な実施形態について添付図を参照しつつ詳細に説明する。下記の説明において、本発明の要旨のみを明確にする目的で、関連した公知機能または構成に関する具体的な説明は省略する。
【0022】
まず、本発明が適用できるルータ及びルーティング方式に関して説明する。Chan et al. (A Framework for Optimizing the Cost and Performance of Next−Generation IP Routers, IEEE Journal of Selected Areas in Communications, Vol. 17, No.6, pages 1013−1029, June 1999)は、高速ルータ構造の主要傾向である分散構造及び並列構造に分類され、この分類は、フォワーディングエンジンの位置によって区分される。高速バックボーン(backbone)ルータは、従来の集中構造より分散構造を取る傾向である。
【0023】
図1は、本発明が適用できる分散構造を有するルータを示す図である。図1を参照すると、ルータは、パケットが入力及び出力されるフォワーディングエンジン(Forwarding Engine: FE)が装着されたラインカードモジュール(line card module)110、初期ルーティングテーブル(RT)の構築及び該ルーティングテーブルの管理を遂行するルーティングプロセッサ(routing processor)120、及びパケットがルータ内において特定のポート(port)にスイッチングされる時に使用されるスイッチファブリック(switch fabric)130から構成される。
【0024】
ルーティングプロセッサ120は、最近変更されたルートを反映することによって更新されたルーティングテーブル(RT)を備える。ルーティングテーブル(RT)は、RIP(Routing Information Protocol)、OSPF(Open Shortest Path First)、またはBGP−4(Border Gateway Protocol 4)などのルーティングプロトコルから生成されるが、これらプロトコルに限定されない。効率的な検索のために考案されたフォワーディングテーブル(FT)であるコンパクトテーブルは、ルーティングプロセッサ120のルーティングテーブルからコピーされる。フォワーディングテーブルは、ルートの追加及び削除の効率性を犠牲にすることによって、検索効率のみのために設計された。
【0025】
ラインカードモジュール110から受信されるパケットがフォワーディングテーブル(FT)から目的経路を発見することができない場合、当該パケットは、スイッチファブリック130を通してルーティングプロセッサ120に移動して発見できなかった経路に対する問題を解決すべきである。目的地を発見した後、前記パケットは、出力ラインカードモジュール110に伝送されるために、再びスイッチファブリック130に伝送されるべきである。ルーティングプロセッサ120がルーティングテーブル(RT)を通しても目的経路を発見することができなかった場合、前記パケットは、ルーティングプロセッサ120で捨てられる。
【0026】
一方、Asthana, A., Delph, C., Jagadish, H., and Krzyzanowski, P., Towards a Gigabit IP Router, J. High Speed Network, vol. 1, no.4, pages 281−288,1992及びPartridge et al. (A 50−Gb/s IP Router, IEEE/ACM Trans. on Networking, vol. 6, no.3, pages 237−248, 1998)は、並列構造のルータに関して開示している。図2は、本発明が適用できる並列構造を有するルータを示す図である。図2に示す並列構造のルータにおいて、フォワーディングテーブル(FT)を有する各フォワーディングエンジン112は、ラインカードモジュール110において分離される。このような並列構造は、各フォワーディングエンジンにおいて並列パケット処理及びルートルックアップを取り扱うためにクライアント及びサーバー基盤のモデルを利用する。
【0027】
ルーティングプロセッサ120におけるルーティングテーブルは、変更されたルートを直ちに反映して容易に維持することができるように設計されるべきである。さらに、追加または削除されるルートは、フォワーディングエンジン112におけるフォワーディングテーブル(FT)に最小の費用でなるべく迅速に反映されるべきである。ルートが反映されなかった場合、受信(incoming)パケットは、スイッチファブリック130を通してルーティングプロセッサ120に伝送されるので、当該パケットを処理するために要求される追加的なルートを通したバイパッシング(bypassing)によって伝送遅延が増加する。
【0028】
以上、分散構造及び並列構造を参照して本発明を説明したが、他の構造を有するルータにも適用できることは、当該技術分野における通常の知識を持つ者には明らかである。
【0029】
図3は、分散または並列構造を有するルータにおけるフォワーディングエンジン112の構造を示す図である。図4は、ルーティングプロセッサ120の構造を示す図である。
【0030】
図3を参照すると、フォワーディングエンジン112は、n個の入力インターフェース(input interface)、m個の出力インターフェース(output interface)、入力インターフェースを通して入力されるパケットをバッファリングするn個のバッファ(buffer)、該バッファに貯蔵されたパケットを等級及び種類別に分類するパケット分類器(packet classifier)、及びフォワーディングテーブル及びパケット分類器によって分類されるパケットをフォワーディングテーブルを参照して該当出力インターフェースに伝送するルートルックアップ(route lookup)制御部を備える。
【0031】
図4を参照すると、ルーティングプロセッサ120は、図1及び図2に示すスイッチファブリック130との間でパケットを送受信するn個の入/出力インターフェース(input/output interface)、この入/出力インターフェースを通して入出力されるパケットをバッファし、スイッチファブリック130と後段のルートルックアップ及び管理制御部との間をインターフェーシングするスイッチインターフェース(switch(or IPC) interface)、及びルーティングテーブル及びスイッチインターフェースから提供されるパケットをルーティングテーブルを参照してスイッチインターフェースを通じ対応する入/出力インターフェースに伝送するルートルックアップ及び管理制御部(route lookup and maintenance)を備える。
【0032】
RFC標準によると、ルーティングテーブル(または、フォワーディングテーブル)は、検索のために主に使用されるデータ構造である配列(array)、ツリー(tree)、及びトライ(trie)及びこれらを取り扱うために使用されるアルゴリズムに対しては制約がない。しかしながら、最長プレフィックスのマッチングのために、最小のメモリアクセスが必要になり、ルーティングテーブル(または、フォワーディングテーブル)内で変更されたルートが容易に更新されるべきである。
【0033】
このために、本発明の実施形態において無作為抽出アルゴリズム(randomized algorithm)を利用する。この無作為抽出アルゴリズムは、実行中にランダムな選択をするアルゴリズムである。無作為抽出アルゴリズムは、全ての入力に対してうまく動作(well−behaved)できる設計分野に主に使用されている。これは、ある入力の処理において特定の仮定に基づいて処理することでなく、確率(例えば、コイン投げ)pに基づいて処理する。無作為抽出アルゴリズムの長所は、その単純性及び効率性にある。
【0034】
無作為抽出アルゴリズムに基づいた本発明によるアルゴリズムは、最小のメモリアクセス数及びルーティングテーブルの簡単な管理を提供する。ルーティングエントリの管理の場合、全体のテーブルを再構成する従来の方式の代わりに、変更されたルート情報のみを再構成する。さらに、従来の一般的なツリーまたは2進検索トライ(binary trie)のようなルートルックアップアルゴリズムとは異なって、本発明によるアルゴリズムは、図5に示す目的地IPアドレスのテール(tail)から最長プレフィックスを検索する。
【0035】
さらに、本発明においては、ルーティングテーブルのために、Pugh, W., Skip Lists: A Probabilistic Alternatives to Balanced Trees, CACM 33(6), pages 6689−676, 1990に提示されたスキップリスト(skip list)を使用する。
【0036】
このスキップリストは、分類(sorting)されたn個のノードを有するリンクリスト(linked list)としてみなされ、通常、“spray tree”などの“balanced tree”に代わったデータ構造に使用される。これは、Sleator, D. and Tarjan, R., Self−Adjusting Binary Search Trees, JACM, Vol. 32, No. 3, July 1985を参照する。従って、スキップリストは、挿入及び削除の動作のための“balanced tree”より単純で効率的である。本発明は、図6に示すように、最長プレフィックスマッチング(longest prefix matching)のために変形したスキップリスト(variant of skip list)を提案する。
【0037】
図6は、本発明の実施形態によるスキップリストの変形を示す図である。図6を参照すると、各ノードは、1つまたは多数のポインタを有し、最左のノードはヘッダノード(header node)210と称されるが、その理由は、検索、追加、削除、及び更新などのスキップリストの変形に対する全ての演算(operation)がヘッダノード210から始まるからである。
【0038】
ヘッダノード210は、キー値として+∞を含み、次のノードを示すためにポインタを含む。ノード220、230、240、250、及び260のキーは、減少の順に分類(sorting)される。各ノードのキーは、‘プレフィックス長さ範囲’または‘プレフィックス長さ値のクラスタリング(clustering)’を意味し、このキーは、減少の順に挿入される。本発明の実施形態において、検索は、既存のトライまたはツリーとはまったく異なる方式であり、葉(leaves)から根(root or parent)(つまり、反転したキー値シーケンス)に遂行される。
【0039】
第2ノード220のキーは、32〜24のプレフィックス長さ範囲を有し、このプレフィックス長さ範囲に属するプレフィックス長さを有するルートは、各プレフィックス長さに対応するハッシュテーブル(hash table)を有する。図6は、第2ノード220の範囲に属するルートのハッシュテーブルの例として、プレフィックス長さが30ビットであるハッシュテーブル222及びプレフィックス長さが24ビットであるハッシュテーブル224を示す。さらに、図6は、17〜12のプレフィックス長さ範囲を有する第4ノード240の範囲に属するルートのハッシュテーブルの例として、プレフィックス長さが15ビットであるハッシュテーブル242を示す。
【0040】
図6に示すように、多様なノードのプレフィックス長さ範囲は異なる長さ、つまり、固定的に分けられたプレフィックス範囲に固定されるが、このようなプレフィックス長さ範囲は、可変的な長さ、つまり、可変的に分けられたプレフィックス範囲を有するノードのグループ(group)に分けられることもできる。Srinivasan, V. and Varghese, G., Faster IP Lookups using Controlled Prefix Expansion, In Proceedings of ACM Sigmetrics ’98 Conf., pages 1−11, 1998は、最善の記憶装置を提供するためにプレフィックス範囲を分割する動的プログラミング(dynamic programming)技術に関して開示する。本発明の実施形態によるアルゴリズムにおいて、類似した方式を使用してプレフィックス長さグループを分けることができる。しかしながら、図6に示す本発明の実施形態において、固定したプレフィックス長さ範囲を有することが望ましく、これによって、動的プログラミングによる追加的な計算作業負荷を避けることができる。
【0041】
IPv4のケースにおいて、プレフィックス長さ範囲が8に固定される場合、挿入されるノードの総数は5(1+[32/8](ここで、32はIPv4アドレスにおける最大のビット数である))になることができる。IPMA(Internet Performance Measurement And Analysis : http://nic.merit.edu/ipmaを参照)からの実験結果から示すように、実際に参照されるプレフィックス長さの非対称的な分散(skewed distribution)は、実際に参照されるプレフィックス長さ分散に存在する局所性パターン(locality pattern)を示す。従って、本発明において、少数のノードを使用することが可能である。例えば、図7A及び図7Bを参照すると、17から27までのプレフィックス長さが最も頻繁に参照される。従って、該当プレフィックス長さを含む範囲のプレフィックス長さキー値を有する1つのノードを設定し、他のプレフィックス長さ範囲による複数のノードを設定することができる。
【0042】
再び図6を参照すると、ヘッダノード210の変数‘MaxLevel’は、スキップリストに属する全てのノードのうち最大のレベル値、つまり、ヘッダノードにおいて他のノードをポインティングするためのポインタの総数を示す。各ノードは、ノードxのレベルLでノードxから隣接したノードまでポインティングするためのポインタを示すキー値‘x−>key’(または、key(x))及びポインタ‘x−>forward[L]’(または、next(x, L))を保有する。
【0043】
ヘッダノード210を除いて、ノード内の各キーは、プレフィックス長さ範囲または集合(set)を有する。図6において、ノード220は、32乃至24の範囲のルートエントリを有し、各プレフィックス長さは、対応するプレフィックス長さに一致するルートエントリを貯蔵するためのハッシュテーブルを有する。32から24までの範囲の各プレフィックス長さに対応するルートエントリが存在する場合、該当ノードは、9つの異なるハッシュテーブルをポインティングするための9つのポインタを有する。各ハッシュテーブルは、各プレフィックス長さに正確に一致するルートエントリのみを貯蔵する。これは、スキップリストの変形を‘k−ary hashed node’を有するスキップリストと称する理由である。
【0044】
本発明によるスキップリストに基づいたアルゴリズムに対する理解を容易にするために、ヘッダノードの生成及び様々なスキップリストの構築方法に関して説明する。
【0045】
図8は、本発明の実施形態によるヘッダノードの生成方法に関して説明する図である。図8を参照すると、ヘッダノードは、+∞キー値及びMaxLevel=5(1+[32/8])を有し、ここで、MaxLevel=1+[W/n]である。WはIPアドレスのビット長さ、例えば、IPv4:32及びIPv6:128であり、nはプレフィックス範囲である。ヘッダノードは、包括的にスキップリスト内の全てのノードを取り扱うべきであるので、IPv4の場合、前記確率pが1/2であり、プレフィックス範囲が1であると、232に達するルートを有するデータ構造用としてMaxLevel=32が適切である。ヘッダノードは、0乃至MaxLevel−1のインデックスが付けられたMaxLevel個の伝送ポインタを有する。本発明の実施形態において、プレフィックス範囲を固定的にまたは可変的にクラスタリングすることによって、固定プレフィックス範囲が8であると仮定する場合、MaxLevel=5が要求される。
【0046】
ヘッダノードが生成された後、スキップリストの異なる部分に対する構築に関して図9を参照して説明する。図9は、本発明の実施形態によるスキップリストの構築動作を説明するための図である。ヘッダノードの最上位のレベルのポインタがヌル(null)である場合、つまり、ヘッダノードのポインタに連結されたサブノードである隣接したノードが存在しない場合、前記レベルは、ポインタが隣接したノードを示すまで1ずつ減少される。図9を参照すると、32〜24のプレフィックス範囲値を有する第1ノード(a)が生成され、ヘッダノードにおいてレベル0のポインタはその第1ノードを示す。次に、23〜18のプレフィックス範囲を有する第2ノード(b)及び17〜12のプレフィックス範囲を通する第3ノード(c)が順次に生成される。この生成過程において、全てのプレフィックス長さ範囲をカバーすることができるように複数のノードが生成される。
【0047】
それぞれ生成されたノードのレベルは、プログラム3に示すように、本発明による無作為抽出アルゴリズムを利用して無作為に設定される。まず、(0,1)に属する実数の乱数値が生成される。この生成された乱数値が予め設定された基準確率値(ここで、基準確率は、理想的なスキップリストの生成のためにp=1/2に設定される)より小さく、生成しようとする該当ノードのレベルがMxLevelより小さい場合、該当ノードのレベルは増加される。そうでない場合、レベル値0を有するノードが生成される。
【0048】
このように、スキップリストにおいてプレフィックス範囲によってノードを構成した後、ルートエントリを含むルーティングテーブルが構築されるべきである。図10Aを参照して、ルータがプレフィックス長さ30のルートを有する時、ルーティングテーブルを構築する方法に関して説明する。
【0049】
図10Aを参照すると、ルータがプレフィックス長さ30のルートを有する時、スキップリストにおいて32〜24のプレフィックス長さ範囲を有する第1ノード220が検索され、次に、追加されるルートエントリがハッシュテーブルの形態で挿入される。スキップリストのノードは、対応するプレフィックス長さによって異なるハッシュテーブルを有する。同一の手順によって、図10Bに示すように、17〜12のプレフィックス範囲を有するノード240下でプレフィックス長さ15のハッシュテーブルが生成されるので、プレフィックス長さ15のルートが追加される。
【0050】
ルーティングテーブルの生成の手順を簡略に説明すると、図11のようである。図11は、本発明の実施形態によるルーティングテーブル構築の過程を示す図である。段階11aで、スキップリスト内の全てのノードを取り扱うためのMaxLevelを有するヘッダノードが生成される。次に、段階11bで、固定分割されたプレフィックス範囲を有するノードがリストに挿入される。段階11bの動作を簡略化するために、本発明は固定分割されたプレフィックス範囲を提案しているが、実際プレフィックス長さ分散が反映されるように適応的に分割されたプレフィックス範囲を設定することもできる。それから、段階11cで、対応するプレフィックス範囲を有するノード下で、それぞれの所定のルートエントリのためのハッシュテーブルが生成される。本発明による新しい方式は、最短のプレフィックス長さから検索する従来の一般的なトライまたはツリー構造とは異なって、最長プレフィックス長さを有するルートから始まる検索を提供する。
【0051】
ルータは、接続された他のルータからしばしばルート変更情報を受信する。この変更は、現在のルーティング(または、フォワーディング伝送)テーブルに反映されるべきである。前述したように新しい方式による更新作業に対して、図12を参照して説明する。所定の変更されたルート(プレフィックス)をルーティングテーブルに反映するために、段階12aで、プレフィックス長さに一致するノードを発見する。それから、段階12bで、変更されたルートと同一のプレフィックス長さを有するハッシュテーブルを検索する。段階12cで、該当ハッシュテーブルが発見されたと確認された場合、段階12dに進行して、該当ハッシュテーブル内の前記検出されたルートを更新または削除する。段階12cで、該当ハッシュテーブルが存在しないと確認される場合は、段階12eに進行する。段階12eで、前記ルートが追加された場合、段階12fに進行して、当該変更ルートと同一のプレフィックス長さを有するハッシュテーブルを生成する。それから、段階12gで、変更ルートは、新しく生成されたハッシュテーブルに挿入される。前記ルートが追加されなかった場合、段階12hで、当該変更ルートは捨てられる。
【0052】
図13及び図14は、本発明の実施形態によるルート検索及びルート更新の過程を説明するための図である。
【0053】
まず、図13を参照して、プレフィックス長さ15のルートを検索する過程を説明する。まず、同一のプレフィックス長さ15を有するノードを発見する。この検索は、ヘッダノード210の最上位レベル(レベル4)から始まる(図13の段階(1))。レベル4のポインタは、レベル4を有する次のノード、つまり、8〜1のプレフィックス長さ範囲(キー)を有するノード260をポインティングする(図13段階(2))。それから、当該ルートのプレフィックス長さとノード260のキーとの比較が遂行される。キー値は一致せず、検索はヘッダノード210の同一のレベル(例えば、レベル4)に戻る(図13の段階(3))。ヘッダノード210のレベルは1の分だけ減少され(図13の段階(4))、次のレベル(レベル3)のポインタはレベル3を通する次のノード、つまり、17〜12のキーを有するノード240をポインティングする(図13の段階(5))。ノード240において一致するキー値が発見された(図13の段階(6))場合、変更されたルートのプレフィックス長さに対応するハッシュテーブルを検索する(図13の段階(7))。ハッシュテーブルが存在する場合、次のホップ(hop)(図13の段階(8))が遂行される。ハッシュテーブルが存在する場合、そのハッシュテーブルは新しいルートを追加するために生成される。
【0054】
図14は、次のホップ(hop)インターフェースが‘10’であるプレフィックス‘111010…1’を有するルートが、ハッシュテーブルから削除されるか、それもと次のホップが‘1’である‘111011…1’に変更される多数の段階を示す。該当プレフィックス(111010…1)を検索する段階は、図13に示す過程と類似して遂行される。
【0055】
以下、図15及び図16を参照して、ルーティングテーブルから特定の目的地IPアドレスのルートを検索するルートルックアップ動作を詳細に説明する。
【0056】
図15及び図16は、本発明の実施形態によるルートルックアップの過程を最長プレフィックスマッチング方式(longest prefix matching scheme)として定義する。この最長プレフィックスマッチング方式に基づいた検索は、ルートエントリが最長プレフィックス、例えば、IPv4のプレフィックス長さ32から比較されるべきであることを意味する。図16は、本発明の実施形態による全体のルックアップ方式を説明するための図であり、ここで、目的地アドレスは、‘1110101…1’のプレフィックス長さ15を有する。
【0057】
図15の段階15aで、IPヘッダにおいてカプセル化(encapsulated)した所定の目的地アドレスに対して、スキップリストの第1ノードが検索される。従って、目的地アドレスによって与えられたルートルックアップは、ヘッダノード
210のレベル4から始まり(図16の段階(1))、ヘッダノード210のレベルは、レベル0になるまで1ずつ減少され(図16の段階(2))、レベル0は、第1ノード210をポインティングするポインタを有する(図16の段階(3))。
【0058】
段階15bで、プレフィックス長さ範囲の上位キー値、例えば、32(現在のプレフィックス長さ)から開始して第1ノード220のハッシュテーブルを検索する。ハッシュテーブルが存在しない場合、前記過程は段階15gに進行する。反対に、段階15cで、ハッシュテーブルが存在する場合、過程は段階15dに進行する。段階15dで、ハッシュテーブル内で目的地アドレスに対応するプレフィックスを検索する。段階15eで、検索されたプレフィックスが目的地アドレスと一致する場合、段階15fで、一致したプレフィックスを最長プレフィックスとしてリターン(return)する。一方、段階15eで、プレフィックスが一致しない場合、過程は段階15gに進行する。
【0059】
段階15gで、過程は、同一のプレフィックス範囲において次のハッシュテーブルを検索する。段階15hで、次のハッシュテーブルが存在する場合、前記過程は、15bに進行して前述した過程を繰り返す。段階15hで、次のハッシュテーブルが存在しない場合、過程は段階15iに進行してスキップリストにおいて隣接したノードに移動し、段階15bに戻って前述した過程を当該隣接したノードにおいて繰り返す。以上のように、本発明による新しい検索方式は、従来のルートノードから始まる検索方式とは異なって、自体のハッシュテーブルを有する最長プレフィックス範囲から始まる検索に基づいている。
【0060】
図16を再び参照すると、まず、前述したように、スキップリストにおいてノードを探し、所定の目的地アドレスによってルートルックアップがヘッダノードから始まる(図16の段階(1))。ヘッダノード210におけるレベルは、ポインタが最長プレフィックス範囲を有するノードをポインティングするレベル0になるまで減少され(図16の段階(2))、次に、ヘッダノード210のポインタによってポインティングされる第1ノード220を横切る(図16の段階(3))。従って、第1ノード220は、プレフィックス長さ32を含むハッシュテーブルを探すために検索される。該当ハッシュテーブルが検索された場合、目的地アドレスは、一致を発見するために、そのハッシュテーブル内のプレフィックスと比較される。スキップリスト内の各ノードがノードプレフィックス範囲内の各ハッシュテーブルをポインティングするポインタアレイ(pointer array)を維持するので、長さ32のプレフィックスを含むハッシュテーブルが存在しない場合、ポインタに対応するプレフィックスはヌル(null)になる。
【0061】
図16の例において、第1ノード220は、それぞれプレフィックス長さ30及びプレフィックス長さ26に対応するハッシュテーブル222及び224のみを有する。従って、ハッシュテーブルを発見するために第1ノード220を検索する時、プレフィックス範囲における各ポインタを検査し、ヌル値を有するポインタはスキップされる。ヌル値を有しないポインタに対応するハッシュテーブルは、元の目的地アドレスと比較されて一致を探す。
【0062】
従って、ヌル値を有する第1ポインタは、ハッシュテーブル222をポインティングし、目的地アドレスは、ハッシュテーブル222においてプレフィックスと比較される(図16の段階4)。ハッシュテーブル222において目的地アドレスが検索されなかった場合、非ヌルのポインタを有する次のハッシュテーブル、つまり、プレフィックス長さ26のハッシュテーブル224が、目的地アドレスと比較される(図16の段階(5))。目的地アドレスが発見されず、第1ノード220においてハッシュテーブルがそれ以上存在しない場合、ノード220に対してルックアップは失敗になる。
【0063】
第1ノード220においてルックアップが失敗した時、次の最長プレフィックス範囲を有するスキップリストにおいて次のノードを示すポインタを検索する。この例において、次の最長プレフィックス範囲を有するスキップリストにおける次のノードが第2ノード230であることを示すポインタがある(図16の段階(6))。従って、どのハッシュテーブルを有するかノード230を検査して、ハッシュテーブルが存在しない場合、スキップリストにおいて次のノードをポインティングするノード230のポインタを検索する。
【0064】
この場合、スキップリストにおいて隣接したノード240に移動し(図16の(7))、図15に示す段階によってハッシュテーブルをポインティングするポインタを発見する。目的地アドレスは、プレフィックス長さ15のハッシュテーブル242においてプレフィックスと比較される(図16の段階(8))。この比較によって一致が発生すると、ルートルックアップ動作は成功に終了する(図16の段階(9))。最後のノード260の最後のハッシュテーブルにおいて目的地アドレスが発見できなかった場合、ルックアップは失敗し、対応するアドレスを有するパケットは、デフォルトルートエントリを有するルートに送られる。
【0065】
以下、スキップリストの構築はプログラム1、2、及び3(数式1、2、3で示す)において表現され、ルートエントリの変化のスキップリストへの反映は、プログラム4、5、6、及び7(数式4、5、6、7で示す)において示し、新しいアルゴリズムの基本部分であるルートルックアップはプログラム8(数式8で示す)において示す。
【0066】
【数1】
Figure 2004517519
【0067】
【数2】
Figure 2004517519
【0068】
【数3】
Figure 2004517519
【0069】
【数4】
Figure 2004517519
【0070】
【数5】
Figure 2004517519
【0071】
【数6】
Figure 2004517519
【0072】
【数7】
Figure 2004517519
【0073】
【数8】
Figure 2004517519
【0074】
ここで、図7A及び図7Bを参照して、本発明によるルーティング方式の効率を説明する。図7A及び図7Bは、インターネット上におけるプレフィックス長さ分布の測定値を示すグラフである。図7A及び図7Bのグラフによって表現されるデータは、IPMA(Internet Performance Measurement and Analysis)プロジェクトで最近MAE−EAST NAP(Network Access Point)において収集されたデータを示す。
【0075】
IPMAプロジェクトで収集された統計データは、ルートルックアップアルゴリズム開発者の研究結果を相互に分析する源泉データとして広く使用される。MAE−EAST NAPにおけるルータは、最大のルートエントリを含み、主にバックボーン(backbone)ルータのモデルとして使用される。PAIX NAPは、現在のIPMAプロジェクトで収集された最小のルートエントリを含み、主にエンタープライズ(enterprise)ルータのモデルとして利用される。
【0076】
図7A及び図7Bは、16〜28のプレフィックス長さが最も頻繁に参照されることを示す局所性パターン(locality pattern)を示す。従って、このような観測結果は、本発明において提示された変更スキップリストに含まれるノードの数が大きく減少されることを示す。IPMA(http://nic.merit.edu/ipma)における他の興味深い結果は、一日にBGPによって追加されるか、それとも撤回されたルーティングプレフィックスの数が1,899,851(1997年11月1日現在)に達することである。これは、25prefix−updates/secを要求するほどに緊迫であり、変更されたルーティングプレフィックスをルーティングテーブル(または、フォワーディングテーブル)に迅速に反映することは検索時間以外に主要要素である。
【0077】
以下、表2を参照して、本発明によるアルゴリズムと従来のアルゴリズムとの差に関して説明する。通常、アルゴリズムに対する分析は、該当アルゴリズムを処理するために要求される時間または使用するメモリに対する“worst−case complexity”を“big−O notation”を使用して相互に比較する。表2は、本発明による新しいアルゴリズムによって要求される複雑度を示す。ここで、N個のルートエントリが存在し、各アドレスを表現するためにW個のアドレスビットが要求され、kはアルゴリズム依存性常数(algorithm−dependent constant)である。
【0078】
【表2】
Figure 2004517519
【0079】
表2において、ベース(base)10の他の対数(logarithm)との混同を防止するために、ベース2の対数をlgに表現する。
【0080】
IPv4において、Wは32に該当し、IPv6の場合は、128に該当する。前記MAE−EAST及びPAIX NAPにおいて、ルートエントリの数Nは、それぞれ約50,000及び60,000である。この場合、プレフィックス範囲が8であると、‘k−ary hashed node’を有するスキップリストにおけるkは4である。IPv6の場合は16である。
【0081】
本発明によるアルゴリズムは、既存の検索ツリー(search tree)及びトライ(Patricia trie またはLC−trie)に比べて、テーブルの構築、追加及び削除動作の面で優れている。さらに、本発明による新しいアルゴリズムは、“Binary hash table search”(Waldvogel, M., Varghese, G., Turner, J. and Plattner, B., Scalable High Speed IP Routing Lookups, In Proceedings of ACM SIGCOMM ’97, Cannes, France, pages 25−37, 1997)及び“Complete prefix trie”(Tzeng, H. and Pryzygienda, T., On Fast Address−Lookup Algorithms, IEEE Journal on Selected Areas in Communications, Vol. 17, No. 6, pages 1067−1082, June, 1999)に比べて、構築時間及び追加または削除動作において優れている。さらに、表2において、新しいアルゴリズムが純粋のスキップリスト(pure skip list)より優れていることを示す複雑度の結果を理解できる。
【0082】
前述の如く、本発明の詳細な説明では具体的な実施形態を参照して詳細に説明してきたが、本発明の範囲は前記実施形態によって限られるべきではなく、本発明の範囲内で様々な変形が可能であるということは、当該技術分野における通常の知識を持つ者には明らかである。
【0083】
【発明の効果】
前述してきたように、本発明によるアルゴリズムは、無作為抽出アルゴリズムを構成するスキップリスト及びハッシュテーブルを利用して、インターネットプロトコルアドレスのプレフィックス範囲によってノードを生成する。さらに、本発明は、各ノードで設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用するルーティング方式を提供することによって、経路検索時間を最小化し、関連テーブルを効率的に管理する。そうすることによって、高速経路検索が可能になる。このアルゴリズムは、将来使用されるIPv6に適用されることもできる。
【0084】
さらに、本発明は、既存のアルゴリズムに比べて、全ての面で、特に、ルーティングテーブルまたはフォワーディングテーブルの構築、追加、及び削除動作の面で優れていることが複雑度分析結果から分かる。さらに、フォワーディングエンジンにおけるフォワーディングテーブルがルーティングプロセッサにおけるルーティングテーブルと依然として分離される分散形態のルータ構造または並列形態のルータ構造などの最近の構造に対する傾向において、全てのルートエントリでなく前記経路に沿って更新されたルートのみをルータに移すことによって、メモリ帯域幅またはシステムバスコンテンション(contention)が減少される。さらに、経路検索時間の短縮及び全てのルーティング関連テーブルを通した前記一致するルーティング情報の管理は、QoS(Quality of service)、マルチキャスティング、IPSecなどの他の因子を通して性能向上に寄与する。
【図面の簡単な説明】
【図1】
本発明が適用できる分散形態のルータ構造を示す概略図である。
【図2】
本発明が適用できる並列形態のルータ構造を示す概略図である。
【図3】
本発明が適用できる伝送エンジンの構造を示す概略図である。
【図4】
ルーティングプロセッサの構造を示す概略図である。
【図5】
本発明の実施形態によるLPM(Longest Prefix Matching)アルゴリズムを説明するための図である。
【図6】
本発明の実施形態によるスキップリストの構造を示す図である。
【図7】
Aは、インターネット上におけるプレフィックス長さ分布の測定値を示すグラフである。Bは、インターネット上におけるプレフィックス長さ分布の測定値を示すグラフである。
【図8】
本発明の実施形態によるヘッダノードの構造を示す図である。
【図9】
本発明の実施形態によるスキップリスト構築作業を説明するための図である。
【図10】
Aは、本発明の実施形態によってプレフィックス長さによるルーティングテーブルを構築する作業を説明するための図である。Bは、本発明の実施形態によってプレフィックス長さによるルーティングテーブルを構築する作業を説明するための図である。
【図11】
本発明の実施形態によるルーティングテーブルの生成過程を示すフローチャートである。
【図12】
本発明の実施形態によるルーティングテーブルの更新過程を示すフローチャートである。
【図13】
本発明の実施形態によるルート検索及び更新作業を説明するための図である。
【図14】
本発明の実施形態によるルート検索及び更新作業を説明するための図である。
【図15】
本発明の実施形態によるルートルックアップ過程を示すフローチャートである。
【図16】
本発明の実施形態による全体ルックアップ過程を説明するためのスキップリスト構造を示す図である。

Claims (36)

  1. スキップリストを利用してインターネットプロトコル(IP)アドレス検索のためのルーティング/フォワーディングテーブルを構築する方法において、
    前記インターネットプロトコルアドレスのプレフィックス長さ範囲を予め設定された方式によって分割する過程と、
    前記プレフィックス長さ範囲の分割されたクラスターの個数に基づいた最大レベルを有し、前記スキップリスト内の全てのノードをポインティングするためのヘッダノードを生成する過程と、
    それぞれ前記分割されたプレフィックス長さ範囲をキーとして有し、前記分割されたクラスターの個数の分だけサブノードを生成する過程と、
    からなることを特徴とする方法。
  2. それぞれのサブノードにおいて、前記プレフィックス長さによって提供されるハッシュテーブルに、対応するプレフィックス長さ範囲内のそれぞれのプレフィックス長さに対応するルートエントリを貯蔵する過程をさらに含むことを特徴とする請求項1記載の方法。
  3. 前記ルートエントリは、32ビットまたは128ビットであることを特徴とする請求項2記載の方法。
  4. 前記サブノードの前記ヘッダノードのレベルは、無作為に設定されることを特徴とする請求項1記載の方法。
  5. 前記プレフィックス長さ範囲は、固定的にまたは可変的に分割されることを特徴とする請求項1記載の方法。
  6. 前記プレフィックス長さ範囲は、前記サブノードを通して全てのプレフィックス長さ範囲がカバーされるように分割されることを特徴とする請求項1記載の方法。
  7. 前記ルーティング/フォワーディングテーブルは、それぞれルーティングプロセッサ及びフォワーディングエンジンに備わることを特徴とする請求項1記載の方法。
  8. スキップリストを利用するインターネットプロトコルルーティング/フォワーディングテーブルの生成方法において、
    前記スキップリスト内の全てのノードを取り扱うためにそれぞれのノードをポインティングするヘッダノードを生成する過程と、
    予め設定された方式によって分割されたインターネットプロトコルアドレスのプレフィックス範囲をキーとして有する複数のサブノードを生成する過程と、
    それぞれのサブノードにおいて、対応するプレフィックス長さ範囲におけるプレフィックス長さ別のルートエントリを貯蔵するために、プレフィックス長さ別のハッシュテーブルを生成する過程と、
    からなることを特徴とする方法。
  9. 前記ハッシュテーブルに対応するプレフィックスに一致するルートエントリを貯蔵する過程をさらに含むことを特徴とする請求項8記載の方法。
  10. 前記サブノードの前記ヘッダノードのレベルは、無作為に設定されることを特徴とする請求項8記載の方法。
  11. 前記プレフィックス長さ範囲は、固定的にまたは可変的に分割されることを特徴とする請求項8記載の方法。
  12. 前記プレフィックス長さ範囲は、複数の前記サブノードを通して全てのプレフィックス長さ範囲がカバーされるように分割されることを特徴とする請求項8記載の方法。
  13. 前記ルートエントリは、32ビットまたは128ビットであることを特徴とする請求項8記載の方法。
  14. 前記ヘッダノードは、+∞キー値を有し、0から最大レベル−1までのインデックスが付けられる伝送ポインタを有することを特徴とする請求項8記載の方法。
  15. 前記ルーティング/フォワーディングテーブルは、それぞれルーティングプロセッサ及びフォワーディングエンジンに備わることを特徴とする請求項8記載の方法。
  16. インターネットプロトコルアドレスのプレフィックス範囲の割り当てによって生成されたそれぞれのノードで設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用したルーティング/フォワーディングテーブルの検索方法において、
    検索されるルートのプレフィックス長さに対応するプレフィックス範囲が設定されたノードを見つける過程と、
    前記見つけたノードにおいて前記検索されるルートと同一のプレフィックス長さを有するハッシュテーブルを見つける過程と、
    前記見つけたハッシュテーブルから前記検索ルートを発見する過程と、
    からなることを特徴とする方法。
  17. 前記ノードを見つける過程は、
    前記スキップリストのヘッダノードの最大レベルからポインティングするノードを見つける段階と、
    前記見つけたノードのプレフィックス長さ範囲と前記検索ルートのプレフィックス長さを比較する段階と、
    前記見つけたノードのプレフィックス長さ範囲に前記検索ルートのプレフィックス長さが該当しない場合、前記ヘッダノードの次のレベルでポインティングされるノードを見つける段階と、を含むことを特徴とする請求項16記載の方法。
  18. 前記スキップリストは、ヘッダノード、及び減少される順で予め設定される範囲のキーを有し、それぞれのプレフィックス長さに関連したハッシュテーブルにそれぞれのプレフィックス長さに対応するルートエントリを貯蔵する複数のノードを含むことを特徴とする請求項16記載の方法。
  19. 前記ルーティング/フォワーディングテーブルは、それぞれルーティングプロセッサ及びフォワーディングエンジンに備わることを特徴とする請求項16記載の方法。
  20. 前記ルートエントリは、32ビットまたは128ビットであることを特徴とする請求項16記載の方法。
  21. インターネットプロトコルアドレスのプレフィックス長さ範囲によって生成されたそれぞれのノードで設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用したルーティング/フォワーディングテーブルの更新方法において、
    更新されるルートのプレフィックス長さに対応するプレフィックス範囲が設定されたノードを見つける過程と、
    前記見つけたノードで前記更新されるルートと同一のプレフィックス長さを有するハッシュテーブルを検索する過程と、
    前記ハッシュテーブルを発見した時、前記ハッシュテーブルにおいて該当ルートを更新する過程と、
    からなることを特徴とする方法。
  22. 前記ルートを見つける過程は、
    前記スキップリストのヘッダノードの最大レベルからポインティングするノードを見つける段階と、
    前記見つけたノードのプレフィックス長さ範囲と前記更新されるルートのプレフィックス長さを比較する段階と、
    前記見つけたノードのプレフィックス長さ範囲に前記更新されるルートのプレフィックス長さが該当しない場合、前記ヘッダノードの次のレベルでポインティングされるノードを見つける段階と、を含むことを特徴とする請求項21記載の方法。
  23. 前記ルート更新過程は、更新されるルートを追加、変更、または削除する過程であることを特徴とする請求項21記載の方法。
  24. 前記ハッシュテーブルが発見されない場合、前記更新されるルートと同一のプレフィックスを有するハッシュテーブルを生成する過程と、
    前記生成されたハッシュテーブルに前記更新されるルートを挿入する過程と、をさらに含むことを特徴とする請求項21記載の方法。
  25. 前記スキップリストは、ヘッダノード、及び減少される順で予め設定される範囲のキーを有し、それぞれのプレフィックス長さと関連したハッシュテーブルにそれぞれのプレフィックス長さに該当するルートエントリが貯蔵される複数のノードを含むことを特徴とする請求項21記載の方法。
  26. 前記ルーティング/フォワーディングテーブルは、それぞれルーティングプロセッサ及びフォワーディングエンジンに備わることを特徴とする請求項21記載の方法。
  27. 前記ルートエントリは、32ビットまたは128ビットであることを特徴とする請求項21記載の方法。
  28. インターネットプロトコル(IP)アドレスのプレフィックス範囲の割り当てによって生成されるそれぞれのノードで予め設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリが貯蔵されるスキップリストを利用するルーティング/フォワーディングテーブルのルートルックアップ方法において、
    前記スキップリストの第1ノードから始まって隣接したノードを見つける過程と、
    該当ノードで目的地アドレスとそれぞれのハッシュテーブルを比較する過程と、
    前記ハッシュテーブルが前記目的地アドレスを含む場合、一致するプレフィックスを最長プレフィックスとみなす過程と、
    からなることを特徴とする方法。
  29. 前記ハッシュテーブルが前記目的地IPアドレスを含まない場合、前記スキップリストで次のノードを見つける過程をさらに含むことを特徴とする請求項28記載の方法。
  30. 前記スキップリストは、ヘッダノード、及び減少される順で予め設定される範囲のキーを有し、それぞれのプレフィックス長さに対応するハッシュテーブルにそれぞれのプレフィックス長さに対応するルートエントリを貯蔵する複数のノードを含むことを特徴とする請求項28記載の方法。
  31. 前記比較過程は、
    前記目的地アドレスと前記該当ノードのハッシュテーブルのうち最長プレフィックス長さを有するハッシュテーブルを比較する段階と、
    前記最長プレフィックス長さを有するハッシュテーブルで目的地アドレスを見つけなかった場合、次の最長プレフィックス長さを有するハッシュテーブルと前記目的地アドレスを比較する段階と、を含むことを特徴とする請求項28記載の方法。
  32. 前記ルーティング/フォワーディングテーブルは、それぞれルーティングプロセッサ及びフォワーディングエンジンに備わることを特徴とする請求項28記載の方法。
  33. 前記ルートエントリは、32ビットまたは128ビットであることを特徴とする請求項28記載の方法。
  34. 高速インターネットプロトコルルータにおいて、
    パケットが入出力されるフォワーディングエンジンがそれぞれ装着された複数のラインカードモジュールと、
    前記パケットを内部ポート間にスイッチングするスイッチファブリックと、
    ヘッダノード、及びインターネットプロトコルアドレスのプレフィックス範囲によってそれぞれ生成され、キーとして前記プレフィックス長さ範囲を有し、設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリを貯蔵するルーティングテーブルを含むルーティングプロセッサと、
    から構成されることを特徴とするルータ。
  35. 高速インターネットプロトコルルータにおいて、
    ヘッダノード、及びインターネットプロトコルアドレスのプレフィックス範囲によってそれぞれ生成され、キーとして前記プレフィックス長さ範囲を有し、設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリを貯蔵する複数のノードを有するスキップリスト構造を有するフォワーディングテーブルを備えるフォワーディングエンジンが装着された複数のラインカードモジュールと、
    前記パケットを内部ポート間にスイッチングするスイッチファブリックと、
    ルーティング動作を全般に制御するルーティングプロセッサと、
    から構成されることを特徴とするルータ。
  36. 前記ルーティングプロセッサは、ヘッダノード、及びインターネットプロトコルアドレスのプレフィックス範囲によってそれぞれ生成され、前記プレフィックス長さ範囲をキーとして有し、設定されたプレフィックス長さによるハッシュテーブルの形態でルートエントリを貯蔵する複数のノードから構成されるスキップリスト構造を有するルーティングテーブルを備えることを特徴とする請求項35記載のルータ。
JP2002553673A 2000-12-22 2001-12-21 高速インターネットプロトコルルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための装置及び方法 Expired - Fee Related JP3790217B2 (ja)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US25714800P 2000-12-22 2000-12-22
KR10-2001-0007568A KR100493099B1 (ko) 2000-12-22 2001-02-15 고속 인터넷프로토콜 라우터의 라우팅/포워딩 룩업 및라우팅 테이블 관리
US10/022,210 US7031320B2 (en) 2000-12-22 2001-12-20 Apparatus and method for performing high-speed IP route lookup and managing routing/forwarding tables
PCT/KR2001/002237 WO2002052442A1 (en) 2000-12-22 2001-12-21 Apparatus and method for performing high-speed ip route lookup and managing routing/forwarding tables

Publications (2)

Publication Number Publication Date
JP2004517519A true JP2004517519A (ja) 2004-06-10
JP3790217B2 JP3790217B2 (ja) 2006-06-28

Family

ID=46150048

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2002553673A Expired - Fee Related JP3790217B2 (ja) 2000-12-22 2001-12-21 高速インターネットプロトコルルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための装置及び方法

Country Status (8)

Country Link
US (1) US7031320B2 (ja)
EP (1) EP1344152B1 (ja)
JP (1) JP3790217B2 (ja)
CN (1) CN100428225C (ja)
AU (1) AU2002217593B2 (ja)
BR (1) BR0108595A (ja)
CA (1) CA2400343C (ja)
WO (1) WO2002052442A1 (ja)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007004801A (ja) * 2005-06-24 2007-01-11 Seagate Technology Llc アドレス関連テーブル構造を持つスキップ・リスト
JP2018523955A (ja) * 2015-08-21 2018-08-23 ニュー・エイチ・3・シィ・テクノロジーズ・カンパニー・リミテッドNew H3C Technologies Co., Ltd. ルーティング管理

Families Citing this family (99)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7296089B2 (en) * 1999-08-27 2007-11-13 At&T Corp. Method for improving web performance by adapting servers based on client cluster characterization
US7191168B1 (en) * 1999-08-27 2007-03-13 At&T Corp. Fast prefix matching of bounded strings
US7274697B2 (en) * 2000-11-16 2007-09-25 Tensilica, Inc. Fast IP route lookup with 16/K and 16/Kc compressed data structures
US6963921B1 (en) * 2001-02-16 2005-11-08 3Com Corporation Method and apparatus for hardware assisted TCP packet re-assembly
US7286532B1 (en) * 2001-02-22 2007-10-23 Cisco Technology, Inc. High performance interface logic architecture of an intermediate network node
US6985493B1 (en) * 2001-02-23 2006-01-10 Cisco Technology, Inc. Message aggregator for channelized interface programming
US7227842B1 (en) 2001-04-24 2007-06-05 Tensilica, Inc. Fast IP packet classification with configurable processor
US7230912B1 (en) * 2001-06-14 2007-06-12 Juniper Networks, Inc. Sampling to a next hop
US7315900B1 (en) 2001-06-20 2008-01-01 Juniper Networks, Inc. Multi-link routing
US7382787B1 (en) 2001-07-30 2008-06-03 Cisco Technology, Inc. Packet routing and switching device
US7418536B2 (en) * 2001-07-30 2008-08-26 Cisco Technology, Inc. Processor having systolic array pipeline for processing data packets
US20030028530A1 (en) * 2001-08-06 2003-02-06 Srikanth Nagaraja Method and apparatus for accelerating search functions
US20030084219A1 (en) * 2001-10-26 2003-05-01 Maxxan Systems, Inc. System, apparatus and method for address forwarding for a computer network
US7035256B1 (en) * 2001-10-31 2006-04-25 Redback Networks Inc. Method and apparatus for a routing information base
US7007101B1 (en) * 2001-11-09 2006-02-28 Radisys Microware Communications Software Division, Inc. Routing and forwarding table management for network processor architectures
JP3627697B2 (ja) * 2001-11-16 2005-03-09 日本電気株式会社 パケットの宛先検索システム
US7813346B1 (en) 2001-11-21 2010-10-12 Juniper Networks, Inc. Filter-based forwarding in a network
JP3725070B2 (ja) * 2001-12-21 2005-12-07 株式会社東芝 ネットワークシステム、ルータ、ホスト、プレフィクス管理方法及びipアドレス管理方法
US7519055B1 (en) * 2001-12-21 2009-04-14 Alcatel Lucent Optical edge router
US7085846B2 (en) * 2001-12-31 2006-08-01 Maxxan Systems, Incorporated Buffer to buffer credit flow control for computer network
US7106740B1 (en) * 2002-01-02 2006-09-12 Juniper Networks, Inc. Nexthop to a forwarding table
US7180887B1 (en) * 2002-01-04 2007-02-20 Radisys Patent Properties Routing and forwarding table management for network processor architectures
US8014395B1 (en) * 2002-01-10 2011-09-06 Ericsson Ab Method and apparatus for processing labels
US7307995B1 (en) * 2002-04-05 2007-12-11 Ciphermax, Inc. System and method for linking a plurality of network switches
US20030202510A1 (en) * 2002-04-26 2003-10-30 Maxxan Systems, Inc. System and method for scalable switch fabric for computer network
WO2004002072A1 (en) * 2002-06-21 2003-12-31 Thomson Licensing S.A. Linearly expandable broadcast router apparatus
US6996562B2 (en) * 2002-07-29 2006-02-07 Microsoft Corporation Method and data structure for performing regular expression searches in a fixed length word language
US20040030766A1 (en) * 2002-08-12 2004-02-12 Michael Witkowski Method and apparatus for switch fabric configuration
US7289500B1 (en) 2003-07-17 2007-10-30 Novell, Inc. Method and system for reliable multicast data transmission
US8438302B2 (en) * 2002-08-22 2013-05-07 International Business Machines Corporation Splitting and sharing routing information among several routers acting as a single border router
US6934252B2 (en) * 2002-09-16 2005-08-23 North Carolina State University Methods and systems for fast binary network address lookups using parent node information stored in routing table entries
CN1319347C (zh) * 2002-10-28 2007-05-30 智邦科技股份有限公司 路由方法和路由系统
US7339930B2 (en) * 2002-11-22 2008-03-04 Sun Microsystems, Inc. Method and apparatus for performing an address lookup using a multi-bit trie with backtracking
KR100462864B1 (ko) * 2002-11-22 2004-12-17 삼성전자주식회사 아이피브이6에서 인터페이스 아이디를 이용한 라우팅테이블 관리 방법
US7536476B1 (en) 2002-12-20 2009-05-19 Cisco Technology, Inc. Method for performing tree based ACL lookups
KR100612315B1 (ko) * 2003-02-20 2006-08-16 삼성전자주식회사 핑퐁 방지 기능이 구비된 분산형 라우터 및 그를 이용한핑퐁 방지 방법
US7483430B1 (en) * 2003-02-28 2009-01-27 Cisco Technology, Inc. Hierarchical hash method for performing forward route lookup
US7394809B2 (en) * 2003-03-31 2008-07-01 Intel Corporation Method and apparatus for packet classification using a forest of hash tables data structure
US7453883B1 (en) * 2003-04-14 2008-11-18 Cisco Technology, Inc. Method for compressing route data in a router
US9258765B1 (en) * 2003-05-08 2016-02-09 Dynamic Mesh Networks, Inc. Chirp networks
US7418505B2 (en) * 2003-05-26 2008-08-26 Ewha University Industry Collaboration Foundation IP address lookup using either a hashing table or multiple hash functions
US20050018683A1 (en) * 2003-07-21 2005-01-27 Zhao Yigiang Q. IP address storage technique for longest prefix match
US7840696B2 (en) * 2003-07-25 2010-11-23 Broadcom Corporation Apparatus and method for classifier identification
US7362763B2 (en) * 2003-09-04 2008-04-22 Samsung Electronics Co., Ltd. Apparatus and method for classifying traffic in a distributed architecture router
US7366167B2 (en) * 2003-09-19 2008-04-29 Samsung Electronics Co., Ltd. Apparatus and method for hairpinning data packets in an Ethernet MAC chip
US20050063407A1 (en) * 2003-09-23 2005-03-24 Samsung Electronics Co., Ltd. Apparatus and method for maintaining high-speed forwarding tables in a massively parallel router
US7672302B2 (en) * 2003-11-21 2010-03-02 Samsung Electronics Co., Ltd. Router using switching-before-routing packet processing and method of operation
US8176006B2 (en) * 2003-12-10 2012-05-08 Cisco Technology, Inc. Maintaining and distributing relevant routing information base updates to subscribing clients in a device
KR20050066903A (ko) * 2003-12-27 2005-06-30 한국전자통신연구원 고속 라우팅 시스템에서의 패킷 포워딩 처리장치 및 그를이용한 라우팅 룩업 방법
US7433355B2 (en) * 2004-02-09 2008-10-07 Alcatel Lucent Filter based longest prefix match algorithm
US8090805B1 (en) * 2004-02-17 2012-01-03 Cisco Technology, Inc. System and method for performing cascaded lookups to forward packets
US7515588B2 (en) * 2004-03-18 2009-04-07 Intel Corporation Method and apparatus to support a large internet protocol forwarding information base
ATE343303T1 (de) * 2004-05-11 2006-11-15 Cit Alcatel Netzelement und verfahren zur abbildung von adressinformationen
US20060045088A1 (en) * 2004-08-25 2006-03-02 Nokia Inc. Method of using Patricia tree and longest prefix match for policy-based route look-up
CN1633111B (zh) * 2005-01-14 2010-04-28 中国科学院计算技术研究所 高速网络业务流分类方法
US7590119B2 (en) * 2005-01-27 2009-09-15 Cisco Technology, Inc. Method and apparatus for context-based prefix updates in border gateway protocol
US8040884B2 (en) * 2005-08-08 2011-10-18 Cisco Technology, Inc. Constraining multicast traffic between a layer 2 network device and a router
US20070180128A1 (en) * 2006-01-18 2007-08-02 International Business Machines Corporation User account validity definition in clustered computer systems
KR100666996B1 (ko) * 2006-01-19 2007-01-10 삼성전자주식회사 라우팅 시스템 및 라우트 업데이트 방법
US8161185B2 (en) * 2006-04-24 2012-04-17 Cisco Technology, Inc. Method and apparatus for assigning IPv6 link state identifiers
US7784022B2 (en) * 2006-04-25 2010-08-24 Sap Ag Mapping a new user interface onto an existing integrated interface
CN101491015A (zh) * 2006-07-27 2009-07-22 佛罗里达大学研究基金公司 用于ip查找和更新的动态树位图
US8127278B2 (en) 2006-09-28 2012-02-28 Sap Ag System and method for extending legacy applications with undo/redo functionality
CN100530182C (zh) * 2006-10-17 2009-08-19 中兴通讯股份有限公司 一种通信系统中字符串匹配信息的处理方法
ITTV20070013A1 (it) * 2007-02-05 2008-08-06 Nice Spa Sistema a bus e relativo protocollo di trasmissione
US8640215B2 (en) * 2007-03-23 2014-01-28 Microsoft Corporation Secure isolation of application pools
US20090006804A1 (en) * 2007-06-29 2009-01-01 Seagate Technology Llc Bi-level map structure for sparse allocation of virtual storage
US8086820B2 (en) * 2007-06-29 2011-12-27 Seagate Technology Llc Data structure for highly efficient data queries
US8091094B2 (en) 2007-10-10 2012-01-03 Sap Ag Methods and systems for ambistateful backend control
TWI413910B (zh) * 2008-01-25 2013-11-01 Univ Nat Taiwan 數值資料範圍區間查詢方法及系統
US7957396B1 (en) * 2008-01-29 2011-06-07 Juniper Networks, Inc. Targeted flow sampling
KR100962653B1 (ko) * 2008-07-24 2010-06-11 이화여자대학교 산학협력단 블룸 필터 및 복수 해싱 구조를 사용한 ip 주소 검색방법 및 장치
US8255496B2 (en) 2008-12-30 2012-08-28 Juniper Networks, Inc. Method and apparatus for determining a network topology during network provisioning
US8959309B2 (en) * 2009-06-18 2015-02-17 Canon Kabushiki Kaisha Skip list generation
US8340636B2 (en) * 2009-11-30 2012-12-25 Airvana Llc Determining if an access terminal is authorized to use an access point
WO2011078812A1 (en) * 2009-12-22 2011-06-30 Bazlamacci Cuneyt F Systolic array architecture for fast ip lookup
CN102299971A (zh) * 2010-06-25 2011-12-28 深圳市邦彦信息技术有限公司 基于fpga的快速地址查找算法
US9471696B2 (en) * 2010-11-12 2016-10-18 Yahoo! Inc. Methods and systems for pathing analysis
EP2643952B1 (en) 2010-11-22 2023-05-31 Nec Corporation Communication system, communication device, controller, and method and program for controlling forwarding path of packet flow
US8891406B1 (en) 2010-12-22 2014-11-18 Juniper Networks, Inc. Methods and apparatus for tunnel management within a data center
US8615015B1 (en) * 2010-12-30 2013-12-24 Juniper Networks, Inc. Apparatus, systems and methods for aggregate routes within a communications network
US9065677B2 (en) * 2012-07-25 2015-06-23 Qualcomm Incorporated Forwarding tables for hybrid communication networks
CN103780490B (zh) 2012-10-17 2018-03-30 中兴通讯股份有限公司 一种更新路由查找树的方法及装置
US9172743B2 (en) * 2012-12-31 2015-10-27 Futurewei Technologies, Inc. Scalable storage systems with longest prefix matching switches
US9536016B2 (en) * 2013-01-16 2017-01-03 Google Inc. On-disk multimap
US9665623B1 (en) * 2013-03-15 2017-05-30 EMC IP Holding Company LLC Key-value store utilizing ranged keys in skip list data structure
US9825857B2 (en) 2013-11-05 2017-11-21 Cisco Technology, Inc. Method for increasing Layer-3 longest prefix match scale
US9361404B2 (en) 2014-05-07 2016-06-07 Red Hat Israel, Ltd. Offline radix tree compression with key sequence skip
US9396286B2 (en) 2014-05-07 2016-07-19 Red Hat Israel, Ltd. Lookup with key sequence skip for radix trees
US9442927B2 (en) 2014-05-07 2016-09-13 Red Hat Israel, Ltd. Offline generation of compressed radix tree with key sequence skip
IL233776B (en) * 2014-07-24 2019-02-28 Verint Systems Ltd A system and method for adjusting domains
US9979650B1 (en) 2015-03-30 2018-05-22 Juniper Networks, Inc. Forwarding packets using a probabilistic filter and a grouping technique
KR20170006742A (ko) * 2015-07-09 2017-01-18 한국전자통신연구원 소프트웨어 라우터, 그 소프트웨어 라우터에서의 라우팅 테이블 검색 방법 및 라우팅 엔트리 갱신 방법
US10897483B2 (en) 2018-08-10 2021-01-19 International Business Machines Corporation Intrusion detection system for automated determination of IP addresses
GB2583962B (en) * 2019-05-16 2022-08-31 Rockley Photonics Ltd Routing protocol and distributed router
JP2020201656A (ja) * 2019-06-07 2020-12-17 ルネサスエレクトロニクス株式会社 検索回路
US11522796B2 (en) 2019-09-05 2022-12-06 Arista Networks, Inc. Routing table selection based on utilization
CN112134805B (zh) * 2020-09-23 2022-07-08 中国人民解放军陆军工程大学 基于硬件实现的快速路由更新电路结构及更新方法
WO2023141378A1 (en) * 2022-01-24 2023-07-27 Salesforce, Inc. Fast skip-list scan and insert

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AU620994B2 (en) * 1989-07-12 1992-02-27 Digital Equipment Corporation Compressed prefix matching database searching
US5796966A (en) * 1993-03-01 1998-08-18 Digital Equipment Corporation Method and apparatus for dynamically controlling data routes through a network
US5671406A (en) * 1995-10-18 1997-09-23 Digital Equipment Corporation Data structure enhancements for in-place sorting of a singly linked list
US6011795A (en) * 1997-03-20 2000-01-04 Washington University Method and apparatus for fast hierarchical address lookup using controlled expansion of prefixes
US6018524A (en) * 1997-09-09 2000-01-25 Washington University Scalable high speed IP routing lookups
US6266706B1 (en) * 1997-09-15 2001-07-24 Effnet Group Ab Fast routing lookup system using complete prefix tree, bit vector, and pointers in a routing table for determining where to route IP datagrams
US6061712A (en) * 1998-01-07 2000-05-09 Lucent Technologies, Inc. Method for IP routing table look-up
US6067574A (en) * 1998-05-18 2000-05-23 Lucent Technologies Inc High speed routing using compressed tree process
US6526055B1 (en) * 1998-10-20 2003-02-25 Sun Microsystems, Inc. Method and apparatus for longest prefix address lookup
IT1305140B1 (it) * 1998-10-27 2001-04-10 Cselt Centro Studi Lab Telecom Memoria per la ricerca di informazioni mediante analisi di prefissi inparticolare per la realizzazione di tabelle di instradamento in nodi
US6237061B1 (en) * 1999-01-05 2001-05-22 Netlogic Microsystems, Inc. Method for longest prefix matching in a content addressable memory
US7027445B1 (en) * 2000-05-26 2006-04-11 Sun Microsystems, Inc. Apparatus and method for finding the longest matching prefix in a router
US7454429B2 (en) * 2004-02-14 2008-11-18 Alan S Rojer Declarative Dispatch

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007004801A (ja) * 2005-06-24 2007-01-11 Seagate Technology Llc アドレス関連テーブル構造を持つスキップ・リスト
JP2018523955A (ja) * 2015-08-21 2018-08-23 ニュー・エイチ・3・シィ・テクノロジーズ・カンパニー・リミテッドNew H3C Technologies Co., Ltd. ルーティング管理
US10880233B2 (en) 2015-08-21 2020-12-29 New H3C Technologies Co., Ltd. Routing management

Also Published As

Publication number Publication date
CN1404591A (zh) 2003-03-19
JP3790217B2 (ja) 2006-06-28
BR0108595A (pt) 2002-11-12
WO2002052442A1 (en) 2002-07-04
EP1344152A1 (en) 2003-09-17
EP1344152A4 (en) 2009-07-01
CA2400343C (en) 2007-07-24
US20020118682A1 (en) 2002-08-29
EP1344152B1 (en) 2015-12-16
CN100428225C (zh) 2008-10-22
CA2400343A1 (en) 2002-07-04
US7031320B2 (en) 2006-04-18
AU2002217593B2 (en) 2004-09-09

Similar Documents

Publication Publication Date Title
JP3790217B2 (ja) 高速インターネットプロトコルルートルックアップ遂行及びルーティング/フォワーディングテーブル管理のための装置及び方法
Taylor Survey and taxonomy of packet classification techniques
US6674769B1 (en) Simultaneous searching of layer 3 policy filter and policy cache in a network switch port
US7039018B2 (en) Technique to improve network routing using best-match and exact-match techniques
US6985483B2 (en) Methods and systems for fast packet forwarding
JP3881663B2 (ja) フィールドレベルツリーを用いたパケット分類装置及び方法
Fu et al. Efficient IP-address lookup with a shared forwarding table for multiple virtual routers
WO2002019624A2 (en) Cluster-based aggregated switching technique (cast) for routing data packets and information objects in computer networks
US20030223421A1 (en) Atomic lookup rule set transition
JP2007202152A (ja) ルーティングシステム及びルーティングシステムのルールエントリー管理方法
US6876655B1 (en) Method for routing with a clue
US7487255B2 (en) Routing cache management with route fragmentation
RU2233473C2 (ru) Устройство и способ выполнения высокоскоростного поиска маршрутов протокола интернет и управления таблицами маршрутизации/пересылки
Sun et al. An on-chip IP address lookup algorithm
US7702882B2 (en) Apparatus and method for performing high-speed lookups in a routing table
Veeramani et al. Efficient IP lookup using hybrid trie-based partitioning of TCAM-based open flow switches
KR100493099B1 (ko) 고속 인터넷프로토콜 라우터의 라우팅/포워딩 룩업 및라우팅 테이블 관리
JP4726310B2 (ja) 情報検索装置、情報検索用マルチプロセッサおよびルータ
Pao et al. Enabling incremental updates to LC-trie for efficient management of IP forwarding tables
KR100459542B1 (ko) 인터넷 프로토콜 주소 룩-업 장치
CN113328947B (zh) 基于应用可控前缀扩展布隆过滤器的可变长路由查找方法及装置
Zhen-Xing et al. High-performance IPv4/IPv6 dual-stack routing lookup
Futamura et al. Scalable, memory efficient, high-speed lookup and update algorithms for IP routing
Chang et al. Efficient IP routing table lookup scheme
Ganegedara et al. 100+ Gbps IPv6 packet forwarding on multi-core platforms

Legal Events

Date Code Title Description
RD03 Notification of appointment of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7423

Effective date: 20040712

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20040803

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20050812

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20050906

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20051205

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20060328

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20060330

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090407

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100407

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110407

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120407

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130407

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20140407

Year of fee payment: 8

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

LAPS Cancellation because of no payment of annual fees