KR100591107B1 - 분산 구조 라우터의 라우팅 처리 방법 및 그 장치 - Google Patents

분산 구조 라우터의 라우팅 처리 방법 및 그 장치 Download PDF

Info

Publication number
KR100591107B1
KR100591107B1 KR20040006791A KR20040006791A KR100591107B1 KR 100591107 B1 KR100591107 B1 KR 100591107B1 KR 20040006791 A KR20040006791 A KR 20040006791A KR 20040006791 A KR20040006791 A KR 20040006791A KR 100591107 B1 KR100591107 B1 KR 100591107B1
Authority
KR
South Korea
Prior art keywords
routing
routing information
information
line card
peer
Prior art date
Application number
KR20040006791A
Other languages
English (en)
Other versions
KR20050078606A (ko
Inventor
고은숙
최병구
박용석
Original Assignee
삼성전자주식회사
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
Application filed by 삼성전자주식회사 filed Critical 삼성전자주식회사
Priority to KR20040006791A priority Critical patent/KR100591107B1/ko
Priority to US11/013,802 priority patent/US20050169281A1/en
Priority to JP2005019645A priority patent/JP4095069B2/ja
Priority to CNA2005100063001A priority patent/CN1652528A/zh
Publication of KR20050078606A publication Critical patent/KR20050078606A/ko
Application granted granted Critical
Publication of KR100591107B1 publication Critical patent/KR100591107B1/ko

Links

Images

Classifications

    • EFIXED CONSTRUCTIONS
    • E02HYDRAULIC ENGINEERING; FOUNDATIONS; SOIL SHIFTING
    • E02DFOUNDATIONS; EXCAVATIONS; EMBANKMENTS; UNDERGROUND OR UNDERWATER STRUCTURES
    • E02D29/00Independent underground or underwater structures; Retaining walls
    • E02D29/045Underground structures, e.g. tunnels or galleries, built in the open air or by methods involving disturbance of the ground surface all along the location line; Methods of making them
    • 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/60Router architectures
    • EFIXED CONSTRUCTIONS
    • E02HYDRAULIC ENGINEERING; FOUNDATIONS; SOIL SHIFTING
    • E02DFOUNDATIONS; EXCAVATIONS; EMBANKMENTS; UNDERGROUND OR UNDERWATER STRUCTURES
    • E02D2450/00Gaskets
    • E02D2450/10Membranes
    • E02D2450/105Membranes impermeable
    • EFIXED CONSTRUCTIONS
    • E02HYDRAULIC ENGINEERING; FOUNDATIONS; SOIL SHIFTING
    • E02DFOUNDATIONS; EXCAVATIONS; EMBANKMENTS; UNDERGROUND OR UNDERWATER STRUCTURES
    • E02D2600/00Miscellaneous
    • E02D2600/20Miscellaneous comprising details of connection between elements

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • General Life Sciences & Earth Sciences (AREA)
  • Mining & Mineral Resources (AREA)
  • Paleontology (AREA)
  • Civil Engineering (AREA)
  • General Engineering & Computer Science (AREA)
  • Structural Engineering (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Environmental & Geological Engineering (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Small-Scale Networks (AREA)

Abstract

본 발명은 분산 구조 라우터에서 라우팅 기능을 분산 처리하는 라인 카드 및 그 방법에 관한 것으로, 분산 구조 라우터에서 라우팅 프로토콜의 처리 기능을 다수개의 라인 카드로 분산하고, 각 라인 카드가 네트워크를 통해 연결되는 피어를 관리함으로써, 분산 구조 라우터의 피어 관리 효율을 향상시키고, 또한, 각 라인 카드에서 독립적으로 연결되는 피어에 대한 라우팅 프로토콜을 처리하여, 분산 구조 라우터에 연결되는 피어의 개수의 증가에 따라 발생하는 부하를 방지하는 것이다.

Description

분산 구조 라우터의 라우팅 처리 방법 및 그 장치{apparatus and method of routing processing in distributed router}
도 1은 일반적인 분산 구조 라우터의 구성을 설명하기 위한 내부 블록 도면.
도 2는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터의 구성을 설명하기 위한 내부 블록 도면.
도 3은 본 발명의 바람직한 실시예에 따른 분산 구조 라우터에서 각 라인 카드의 구성을 설명하기 위한 내부 블록 도면.
도 4는 본 발명의 바람직한 실시예에 따른 라우팅 처리부의 구성을 설명하기 위한 내부 블록 도면.
도 5는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터가 외부 피어와 메시지를 교환하는 흐름을 설명하기 위한 흐름도.
도 6은 본 발명에 따른 각 라인 카드의 라우팅 프로세서간 내부 연결을 설명하기 위한 개념도.
도 7은 본 발명의 바람직한 실시예에 따른 분산 구조 라우터의 라우팅 정보 교환부를 설명하기 위한 내부 블록 도면.
도 8은 본 발명의 바람직한 실시예에 따라 분산 구조 라우터의 각 라인 카드 간 메시지 교환의 흐름을 설명하기 위한 흐름도.
도 9는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터에서 라우팅을 처리하는 방법의 흐름을 설명하기 위한 플로우챠트 도면.
<도면의 주요 부분에 대한 부호의 설명>
100 : 분산 구조 라우터 21~26 : 라인 카드
31~36 : 라우팅 프로세서 311 ; 라우팅 정보 저장부
312 : 라우팅 처리부 321 : 초기화부
322 : 메시지 처리부 323 : 라우트 결정부
324 : RIB 관리부 313 : 라우팅 정보 교환부
331 : 경로 설정부 332 : 라우팅 정보 동기화부
333 : RIB 관리부 334 : 경로 저장부
314 : 라우팅 테이블 41~46 : 포워딩 처리부
411 : 포워딩 관리부 412 : 포워딩 테이블
51~56 : 포트부
본 발명은 분산 구조 라우터의 라우팅 처리 방법 및 그 장치에 관한 것으로, 더욱 자세하게는, 분산 구조 라우터에서 라우팅 프로토콜을 처리하는 기능을 분산하는 분산 구조 라우터의 라우팅 처리 방법 및 그 장치에 관한 것이다.
일반적으로 라우터(router)는 입력 포트(input port), 출력 포트(output port), 스위칭 패브릭(switching fabric), 라우팅 프로세서(routing processor)의 4가지 구성 요소로 이루어져 있다.
입력 포트는 물리적 링크와의 접점이며, 외부로부터 패킷(packet)을 수신하고, 스위칭 패브릭은 입력 포트를 출력 포트로 내부 접속시킨다.
그리고, 출력 포트는 패킷을 출력 링크로 내보내기 위해 패킷을 축적하고. 스케쥴링(scheduling)한다.
마지막으로 라우팅 프로세서는 라우팅 프로토콜(protocol)을 처리하고, 패킷 포워딩(forwarding)에 이용되는 포워딩 테이블을 생성한다.
라우팅 기능을 프로세싱 환경에서 실행되는 소프트웨어로 구현하는 경우, 그 처리 성능이 패킷의 입력 속도를 따라가지 못하면 병목 현상이 발생한다.
따라서, 최근에 인터넷 트래픽이 기하급수적으로 증가하면서 이러한 인터넷 트래픽의 증가를 수용하기 위해 분산 구조를 가진 분산 구조 라우터가 제안되고 있다.
도 1은 일반적인 분산 구조 라우터의 구성을 설명하기 위한 내부 블록 도면이다.
도 1을 참조하면, 일반적인 분산 구조 라우터(100)는, 다수개의 라인 카드(Line Card : LC)(111~116), 스위치 패브릭(130), 라우팅 프로세서(140)를 포함하고, 라우팅 프로세서(140)는 라우팅 테이블을 포함한다.
그리고, 각 라인 카드(111~116)는 포워딩 테이블(Forwarding Table : FT)(121~126)을 포함한다.
라우팅 프로세서(140)는 각 라인 카드(111~116)를 통해 연결되는 외부 피어(peer)에 대한 라우팅을 처리한다.
즉, 라우팅 프로세서(140)는 외부 피어가 네트워크를 통해 연결되면, 각 외부 피어로부터 전송되는 엔트리(entry) 정보를 라우팅 프로토콜에 따라 처리하여, 라우팅 테이블(141)을 생성/관리한다.
라우팅 프로세서(140)에서 처리되는 라우팅 프로토콜은, RIP(Routing Information Protocol), OSPF(Open Shortest Path First), 또는 BGP(Border Gateway Protocol) 등이 된다.
그리고, 각 라인 카드(111~116)는 네트워크를 통해 연결되는 외부 피어로부터 전송되는 엔트리 정보를 스위치 패브릭(130)을 통해 라우팅 프로세서(140)로 전송하고, 라우팅 프로세서(140)에서 라우팅 프로토콜에 따라 생성하는 라우팅 테이블(141)로부터 포워딩 테이블(Forwarding Table : FT)(121~126)을 다운로드한다.
그리고, 포워딩 테이블(121~126)은 각각의 라인 카드(111~116)가 효율적으로 룩업(lookup)할 수 있도록 포워딩 정보를 제공한다.
또한, 각 라인 카드(111~116)는 네트워크로 연결되는 외부 피어로부터 패킷이 전송되면, 해당 패킷을 최종 목적지로 전송하기 위하여, 포워딩 테이블(121~126)을 룩업하고, 그 룩업된 출력 포트를 통해 패킷을 네트워크로 출력한다.
이러한, 분산 구조 라우터(100)는 라우팅 프로토콜이 중앙의 라우팅 프로세서(140)에서만 처리하고 있다.
즉, 라우팅 프로세서(140)에서 라우팅 프로토콜에 의해 생성된 라우팅 테이블(141)에서 포워딩 테이블(121~126)이 생성되고, 이 포워딩 테이블(121~126)에 저장된 포워딩 정보를 통해 분산 구조 라우터(100)의 각 라인 카드(111~116)가 수신되는 패킷의 포워딩/스위칭 기능을 수행한다.
그러나, 이러한 분산 구조 라우터(100)는 전송되는 패킷의 포워딩 기능을 분산하는 구조일 뿐이며, 라우터(100)에서 라우팅 프로토콜의 처리 기능을 분산하는 구조는 아니다.
즉, 일반적인 분산 구조 라우터(100)에서는 라우팅 프로토콜을 처리하는 구조가 라우팅 프로세서(140)에서만 처리하는 중앙 집중식 처리 구조이며, 중앙의 라우팅 프로세서(140)가 서버(server)이고, 각 라인 카드(111~116)가 클라이언트인 서버/클라이언트의 구조를 가진다.
그리고, 서버인 라우팅 프로세서(140)에서 라우팅 프로토콜에 따라 생성되는 라우팅 테이블(141)에서 포워딩 테이블(121~126)이 생성되고, 이러한, 포워딩 테이블(121~126)을 클라이언트인 각 라인 카드(111~116)로 분산시킨다.
또한, 클라이언트인 각 라인 카드(111~116)는 서버인 라우팅 프로세서(140)로부터 다운로드되는 포워딩 테이블(121~126)을 록업하여, 수신되는 패킷을 포워딩 한다.
이러한, 분산 구조 라우터(100)는 중앙의 라우팅 프로세서(140)에서 라우팅 프로토콜의 모든 동작을 처리하기 때문에, 각 라우팅 프로토콜에 따라 처리해야 하는 외부 피어(peer)의 개수가 늘어나게 되면, 중앙의 라우팅 프로세서(140)에서 라우팅 프로토콜을 처리하는 기능의 부하가 증가하게 된다.
예를 들어, 라우팅 프로세서(140)에서 처리하는 라우팅 프로토콜이 RIP(Routing Information Protocol) 또는 OSPF(Open Shortest Path First)인 경우, 각 라인 카드(111~116)를 통해 연결되는 외부 피어 개수가 증가하게 되면, 라우팅 프로세서(140)와 외부 피어간 RIP 또는 OSPF에 따라 주기적으로 송/수신되는 메시지가 증가하게 되고, 이러한, 메시지를 처리하기 위한 라우팅 프로세서(140)의 부하가 증가하게 된다.
또한, 라우팅 프로세서(140)에서 처리하는 라우팅 프로토콜이 BGP(Border Gateway Protocol)인 경우, 각 라인 카드(111~116)를 통해 연결되는 외부 피어와, 분산 구조 라우터(100)와 연결되는 TCP(Transmission Control Protocol) 연결(connection) 수가 증가하게 되고, 이에 따라 라우팅 프로세서(140)의 부하가 증가하게 된다.
아울러, 라우팅 프로세서(140)가 각 라우팅 프로토콜에 따라 최적 라우트(best route)를 결정하기 위한 프로세싱(decision processing)으로 인한 부하도 네트워크를 통해 연결되는 외부 피어의 증가만큼 증가하게 된다.
따라서, 종래의 중앙 집중식의 분산 구조 라우터(100)는 중앙의 라우팅 프로 세서(140)에서만 라우팅 프로토콜을 처리하는 한계로 인하여, 네트워크 시스템의 전체 용량(scalability)이 제한되는 문제가 발생한다.
따라서, 본 발명은 상기와 같은 문제점을 해결하기 위하여 창안된 것으로, 분산 구조 라우터에서 중앙의 라우팅 프로세서에서만 라우팅 프로토콜을 처리하는 중앙 집중식 구조를 탈피하여, 라우팅 프로토콜의 처리 기능을 분산하는 분산 구조 라우터의 라우팅 처리 방법 및 그 장치를 제공하는 것에 그 목적이 있다.
상기 목적을 달성하기 위한 본 발명에 따른 분산 구조 라우터는, 다수개의 라인 카드를 포함하되, 각 라인 카드는, 외부 네트워크를 통해 연결되는 피어로부터 전송되는 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하고, 피어에 대한 라우팅 정보를 타 라인 카드와 설정되는 내부 통신 경로를 통해 교환하여, 각 라인 카드간 라우팅 정보를 동기화하는 라우팅 프로세서와, 정보를 기반으로 포워딩 정보를 구축하고, 네트워크로부터 수신되는 패킷을 처리하는 포워딩 처리부를 포함한다.
본 발명에 따른 라우팅 프로세서는, 피어에 대한 라우팅 정보를 저장하는 라우팅 정보 저장부와, 피어로부터 전송되는 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하여, 피어에 대한 라우팅 정보를 상기 라우팅 정보 저장부에 저장하는 라우팅 처리부와, 타 라인 카드와 내부 통신 경로를 설정하고, 내부 통신 경로를 통해 타 라인 카드와 라우팅 정보를 교환하여, 각 라인 카드간 라우팅 정보를 동기화하는 라우팅 정보 교환부를 포함한다.
그리고, 본 발명에 따른 분산 구조 라우터의 라우팅 처리부는, 외부 피어가 연결되면, 엔트리 정보 요청 메시지를 전송하고, 요청 메시지에 대한 응답으로 전송되는 엔트리 정보를 수신하는 메시지 처리부와, 메시지 처리부를 통해 수신되는 엔트리 정보를 설정된 라우팅 프로토콜에 따라 피어의 최적 라우트를 결정하여, 라우팅 정보를 라우팅 정보 저장부에 저장하는 라우트 결정부를 포함한다.
또한, 본 발명에 따른 분산 구조 라우터의 라우팅 정보 교환부는, 타 라인 카드와 내부 통신 경로를 설정하는 경로 설정부와, 경로 설정부가 설정하는 내부 통신 라우트에 대한 정보를 저장하는 경로 저장부와, 경로 설정부에서 설정되는 내부 통신 경로를 통해 타 라인 카드와 라우팅 정보를 교환하여, 타 라인 카드에 저장된 라우팅 정보와 동일한 라우팅 정보를 라우팅 정보 저장부에 저장하는 라우팅 정보 동기화부를 포함한다.
한편, 본 발명의 다른 측면에 따른 분산 구조 라우터는, 네트워크를 통해 피어와 연결되고, 피어로부터 전송되는 패킷 및 엔트리 정보가 포함된 메시지를 수신하고, 패킷이 목적지로 전송될 수 있도록 출력하는 다수개의 포트와, 각 포트를 통해 수신되는 패킷을 해당 출력 포트로 출력되도록 스위칭하는 스위치 패브릭과, 각 입력 포트를 통해 수신되는 메시지에서 피어의 엔트리 정보를 추출하고, 엔트리 정보를 기설정되는 라우팅 프로토콜에 따라 처리하여, 최적 라우트를 결정하고, 피어로부터 수신되는 패킷이 최적 라우트에 따라 해당 출력 포트를 통해 출력되도록 하는 적어도 하나 이상의 라인 카드를 포함한다.
그리고, 본 발명에 따른 분산 구조 라우터의 라인 카드는, 피어에 대한 라우팅 정보를 저장하며, 각 입력 포트를 통해 수신되는 엔트리 정보에 따라 피어의 최적 라우트를 결정하고, 최적 라우트에 따른 라우팅 정보를 라우팅 정보 저장부에 저장하고, 타 라인 카드와 상기 라우팅 정보 저장부에 저장된 라우팅 정보를 교환하여 동기화하는 라우팅 프로세서와, 라우팅 정보 저장부에 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하고, 각 포트를 통해 수신되는 패킷의 출력 포트를 상기 포워딩 정보에서 서치하여, 해당 출력 포트로 상기 패킷을 출력하는 포워딩 처리부를 포함한다.
아울러, 본 발명의 또 다른 측면에 따른 분산 구조 라우터의 라우팅 처리 방법은, 각 라인 카드가 네트워크로 연결되는 피어의 라우팅 정보를 라우팅 프로토콜에 따라 생성하여 저장하는 단계와, 분산 구조 라우터의 각 라인 카드간 내부 통신 경로를 설정하고, 설정된 내부 통신 경로를 통해 라인 카드에 저장되는 라우팅 정보를 교환하여, 동기화하는 단계와, 각 라인 카드가 변경되는 라우팅 정보가 있으면, 내부 통신 경로를 통해 타 라인 카드로 전송하여, 라우팅 정보의 동기화를 유지하는 단계와, 각 라인 카드가 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하는 단계와, 임의 라인 카드가 패킷이 수신되면, 구축된 포워딩 정보에 따라 포워딩 처리를 수행하는 단계를 포함한다.
그리고, 본 발명에 따른 분산 구조 라우터의 라우팅 처리 방법은, 임의 라인 카드가 피어와 연결이 종료되면, 피어에 대한 라우팅 정보를 삭제하고, 라우팅 정보 삭제를 타 라인 카드로 전송하는 단계와, 임의 라인 카드가 신규 피어와 연결되면, 피어의 엔트리 정보에 따른 최적 라우트를 결정하여, 신규 라우팅 정보를 저장하고, 타 라인 카드로 신규 라우팅 정보를 전송하는 단계와, 임의 라인 카드가 신규 실장되면, 라인 카드와 내부 통신 경로를 설정하고, 내부 통신 경로 정보를 저 장하는 단계와, 라인 카드가 연결되는 피어의 엔트리 정보에 따른 최적 라우트를 결정하여, 라우팅 정보를 저장하고, 라우팅 정보를 내부 통신 경로를 통해 타 라인 카드로 전송하는 단계와, 임의 라인 카드가 탈장되면, 라인 카드와 내부 통신 경로를 종료하고, 내부 통신 경로가 종료되었음을 저장하는 단계를 더 포함한다.
그리고, 본 발명에 또 다른 측면에 따른 분산 구조 라우터의 라우팅 처리 방법은, 각 라인 카드가 네트워크로 연결되는 피어의 라우팅 정보를 라우팅 프로토콜에 따라 생성하여 저장하는 단계와, 분산 구조 라우터의 각 라인 카드간 내부 통신 경로를 설립하고, 라인 카드가 내부 통신 경로를 통해 라우팅 정보를 교환하여, 라우팅 정보를 동기화하는 단계와, 임의 라인 카드에 네트워크를 통해 피어가 연결되면, 피어의 엔트리 정보를 설정되는 라우팅 프로토콜에 따라 처리하여, 최적 라우트를 결정하고, 그에 따른 라우팅 정보를 타 라인 카드로 내부 통신 경로를 통해 전송하는 단계와, 임의 라인 카드가 피어와 연결이 종료되면, 피어에 대한 라우팅 정보를 삭제하고, 라우팅 정보 삭제를 타 라인 카드로 전송하는 단계와, 임의 라인 카드에 신규 피어와 연결되면, 피어의 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하여, 신규 라우팅 정보를 저장하고, 타 라인 카드로 신규 라우팅 정보를 전송하는 단계와, 각 라인 카드가 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하고, 패킷이 수신되면, 구축된 포워딩 정보에 따라 포워딩 처리를 수행하는 단계를 포함한다.
이하 본 발명에 따른 분산 구조 라우터의 라우팅 처리 방법 및 그 장치를 첨 부한 도면을 참조하여 상세히 설명한다.
도 2는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터의 구성을 설명하기 위한 내부 블록 도면이다.
도 2를 참조하면, 본 발명에 따른 분산 구조 라우터(100)는, 다수개의 라인 카드(21~26), 스위치 패브릭(60) 및 중앙 처리 장치(CPU : central processing unit)(70)를 포함한다.
그리고, 각 라인 카드(21~26)는 라우팅 프로세서(31~36), 포워딩 처리부(41~46) 및 포트부(51~56)를 포함한다.
CPU(70)는 입력 수단(미도시)을 통해 입력되는 라우팅 프로토콜에 따른 프로그램 정보 등을 각 라인 카드(21~26)로 제공하여, 각 라인 카드(21~26)가 라우팅 프로토콜을 처리할 수 있도록 한다.
그리고, 포트부(51~56)는 각 라인 카드(21~26)가 네트워크를 통해 외부 피어(미도시)와 연결될 수 있도록 인터페이싱을 하고, 외부 피어로부터 네트워크를 통해 전송되는 패킷을 수신하고, 라인 카드(21~26)에서 처리하는 포워딩에 따라 패킷을 네트워크를 통해 출력한다.
또한, 각 라인 카드(21~26)의 각 라우팅 프로세서(31~36)는 포트부(51~56)를 통해 연결되는 각 피어로부터 전송되는 엔트리 정보에 따라 라우팅 프로토콜을 처리하여, 라우팅 테이블을 생성/관리한다.
그리고, 각 라우팅 프로세서(31~36)는 생성된 라우팅 테이블의 라우팅 정보를 타 라인 카드(21~26)로 전송하여, 분산 구조 라우터(100)의 라우팅 정보를 동기화한다. 스위칭 패브릭((60)는 각 라인 카드(21~26)가 라우팅 정보를 동기화할 수 있는 경로를 제공한다.
이때, 각 라우팅 프로세서(31~36)에서 처리하는 라우팅 프로토콜은, 크게 IGP(Interior Gateway Protocol) 및 EGP(Exterior Gateway Protocol)로 나뉠 수 있다.
먼저, IGP에는 RIP(Routing Information Protocol), OSPF(Open Shortest Path First), IGRP(Inter-Gateway Routing Protocol) 및 Inergrated IS-IS(Intermediate System to Intermediate System) 등이 해당된다.
그리고, EGP에는 BGP(Border Gateway Protocol) 등이 해당된다.
또한, 포워딩 처리부(41~46)는 라우팅 프로세서(31~36)에서 라우팅 프로토콜에 따라 생성/관리하는 라우팅 테이블의 라우팅 정보에 따라 포워딩 테이블을 생성/관리하고, 포트부(51~56)를 통해 연결된 외부 피어로부터 전송되는 패킷에 대한 포워딩 처리를 한다.
이하 도 3을 참조하여, 본 발명에 따른 분산 구조 라우터를 좀더 상세하게 설명하기로 한다.
도 3은 본 발명의 바람직한 실시예에 따른 분산 구조 라우터에서 각 라인 카드의 구성을 설명하기 위한 내부 블록 도면이다.
도 3을 참조하면, 라인 카드(21)는, 라우팅 프로세서(31), 포워딩 처리부(41) 및 포트부(51)를 포함하고, 라우팅 프로세서(31)는, 라우팅 처리부(312), 라우팅 정보 교환부(313) 및 라우팅 정보 저장부(311)를 포함한다.
그리고, 포워딩 처리부(41)는 포워딩 관리부(411) 및 포워딩 테이블(412)을 포함한다.
라우팅 프로세서(31)의 라우팅 처리부(312)는 포트부(51)를 통해 연결되는 외부 피어로 엔트리 정보 요청 메시지를 전송하고, 그에 대한 응답으로 외부 피어로부터 전송되는 엔트리 정보가 포함된 응답 메시지에 따라 최적 라우트를 결정한다.
그리고, 라우팅 처리부(312)는 결정된 최적 라우트에 따른 라우팅 정보를 라우팅 정보 저장부(311)에 갱신하고, 그 갱신된 라우팅 정보를 타 외부 피어로 전송한다.
도 4는 본 발명의 바람직한 실시예에 따른 라우팅 처리부의 구성을 설명하기 위한 내부 블록 도면이다.
도 4를 참조하면, 본 발명의 따른 라우팅 처리부(312)는, 초기화부(321), 메시지 처리부(322), 라우트 결정부(323) 및 RIB(Routing Information Base) 관리부(324)를 포함한다.
초기화부(321)는 라인 카드(31)의 초기 구동 또는 분산 구조 라우터(100)에 실장되면, 라인 카드(31)에 설정된 라우팅 프로토콜 및 라우팅 정보 저장부(311)의 라우팅 정보를 초기화한다.
메시지 처리부(322)는 포트부(51)를 통해 외부 피어가 연결되면, 설정된 라우팅 프로토콜에 따라 엔트리 정보 요청 신호를 전송하고, 그에 대한 응답으로 외부 피어로부터 엔트리 정보가 포함된 응답 메시지를 수신한다.
그리고, 메시지 처리부(322)는 외부 피어로부터 전송되는 응답 메시지에 따 라 라우팅 정보 저장부(311)에서 변경되는 라우팅 정보를 타 외부 피어로 전송한다.
또한, 라우트 결정부(323)는 포트부(51)를 통해 연결된 외부 피어로부터 전송되는 엔트리 정보를 라우팅 프로토콜에 따라 처리하여, 해당 외부 피어에 대한 최적 라우트를 판단한다.
그리고, RIB 관리부(324)는 라우트 결정부(323)에서 결정된 최적 라우트에 따른 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다.
즉, RIB 관리부(324)는 외부 피어로부터 전송되는 엔트리 정보에 따라 변경되는 라우팅 정보가 있으면, 라우팅 정보 저장부(311)를 갱신한다.
도 5는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터가 외부 피어와 메시지를 교환하는 흐름을 설명하기 위한 흐름도이다.
도 5를 참조하여, 분산 구조 라우터(100)가 외부 피어 #2(62)와 포트부(51)를 통해 연결되어 있는 상태에서, 외부 피어 #1(61)이 새로 연결되는 경우에 대하여 설명한다.
먼저, 분산 구조 라우터(100)가 외부 피어 #2(62)와 네트워크를 통해 연결되어, 분산 구조 라우터(100)가 외부 피어 #2(62)에 대한 라우팅 정보를 관리하고 있고(S 1), 외부 피어 #1(61)이 분산 구조 라우터(100)에 새로이 네트워크를 통해 연결된다(S 2).
이때, 라우팅 처리부(312)는 초기화부(321)는 해당 라인 카드(21)가 새로이 분산 구조 라우터(100)에 실장되거나, 분산 구조 라우터(100)가 초기 구동되면, 라 우팅 프로토콜 및 라우팅 정보 저장부(311)에 저장된 라우팅 정보를 초기화한다.
그리고, 라우팅 처리부(312)의 메시지 처리부(322)는 네트워크를 통해 새로이 연결되는 외부 피어 #1(61)로 엔트리 정보 요청 메시지(Request Message)를 전송한다(S 3).
외부 피어 #1(61)은 메시지 처리부(322)로부터 전송되는 엔트리 정보 요청 메시지에 대한 응답으로 엔트리 정보가 포함된 응답 메시지(Response message)를 라우팅 처리부(312)의 메시지 처리부(322)로 전송한다(S 4).
그리고, 라우팅 처리부(312)의 메시지 처리부(322)는 외부 피어 #1(61)로부터 전송되는 응답 메시지를 라우트 결정부(323)로 전송한다.
라우트 결정부(323)는 외부 피어 #1(61)로부터 전송되는 응답 메시지에 포함된 엔트리 정보를 라우팅 프로토콜에 따라 처리하여, 외부 피어 #1(61)에 대한 최적 라우트를 판단한다.
그리고, RIB 관리부(324)는 라우트 결정부(323)에서 결정된 최적 라우트에 따른 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다.
이때, RIB 관리부(324)는 분산 구조 라우터(100)가 초기 구동되는 경우, 타 외부 피어(61, 62)에 대한 라우팅 정보에 따른 라우팅 정보 저장부(311)를 생성하고, 이미 라우팅 정보 저장부(311)가 생성된 경우, 라우팅 정보 저장부(311)에 저장된 라우팅 정보를 갱신한다.
그리고, 메시지 처리부(322)는 RIB 관리부(324)가 라우팅 정보 저장부(311)에 생성/갱신하는 라우팅 정보를 이미 연결되어 있는 외부 피어 #2(62)로 전송한다(Trigger Update)(S 5).
이때, 메시지 처리부(322)는 라우팅 프로세서(31)에 처리하는 라우팅 프로토콜의 종류에 따라 주기적으로 외부 피어(61, 62)로 라우팅 정보를 전송하거나, 변경되는 라우팅 정보가 있는 경우에만 외부 피어(61, 62)로 라우팅 정보를 전송할 수 있다.
한편, 외부 피어 #1(61)은 변경되는 엔트리 정보가 있는 경우, 그 변경되는 엔트리 정보를 분산 구조 라우터(100)의 라우팅 처리부(312)로 전송한다(S 6).
이때, 외부 피어 #1(61)은 분산 구조 라우터(100)가 처리하는 라우팅 프로토콜에 따라 주기적으로 엔트리 정보를 전송하거나, 변경되는 엔트리 정보가 있으면, 그 변경되는 엔트리 정보를 분산 구조 라우터(100)로 전송할 수 있다.
그리고, 라우팅 처리부(312)의 메시지 처리부(322)는 외부 피어 #1(61)로부터 변경되는 엔트리 정보가 전송되면, 라우트 결정부(323)로 제공하고, 라우트 결정부(323)는 외부 피어 #1(61)로부터 전송되는 엔트리 정보에 따라 최적 라우트를 판단한다.
또한, RIB 관리부(324)는 라우트 결정부(323)에서 결정되는 최적 라우트에 따른 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다.
그리고, 메시지 처리부(322)는 라우팅 정보 저장부(311)에서 변경되는 라우팅 정보를 외부 피어 #2(62)로 전송한다.
또한, 외부 피어 #2(62)는 변경되는 엔트리 정보를 분산 구조 라우터(100)로 전송한다(S 7).
즉, 분산 구조 라우터(100)는 외부 피어 #1(61)에 대한 라우팅 정보가 변경되면, 외부 피어 #2(62)로 전송하고, 외부 피어 #2(62)에 대한 라우팅 정보가 변경되면, 외부 피어 #1(61)로 전송한다(S 8).
반면, 외부 피어 #1(61) 및 외부 피어 #2(62)가 분산 구조 라우터(100)와의 연결이 종료되면(S 9), 분산 구조 라우터(100)는 외부 피어 #1(61) 및 외부 피어 #2(62)와의 연결이 완전히 종료되었는지 여부를 판단하기 위한 만기 타임을 체크한다(Expire Timeout Timer)(S 10, S 11).
그리고, 분산 구조 라우터(100)는 외부 피어 #1(61) 및 외부 피어 #2(62)에 대한 만기 타임이 만기되면, 외부 피어 #1(61) 및 외부 피어 #2(62)와의 연결을 종료하고, 라우팅 정보 저장부(311)에서 외부 피어 #1(61) 및 외부 피어 #2(62)의 라우팅 정보를 삭제하기 위하여, 만기 정보 제거 타임을 체크한다(Expire Garbage Collection Timer)(S 12, S 13).
분산 구조 라우터(100)는 외부 피어 #1(61) 및 외부 피어 #2(62)에 대한 만기 정보 제거 타임을 체크하여, RIB 관리부(324)은 외부 피어 #1(61) 및 외부 피어 #2(62)로부터 만기 정보 타임 체크 기간내에 응답이 없으면, 라우팅 정보 저장부(311)에서 외부 피어 #1(61) 또는 외부 피어 #2(62)에 대한 라우팅 정보를 삭제한다.
한편, 라우팅 프로세서(31)의 라우팅 정보 교환부(313)는 분산 구조 라우터(100)에 실장되어 있는 각 라인 카드(21~26)간 통신 경로를 연결하고, 각 라인 카드(21~26)의 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보를 교환함 으로써, 라우팅 정보를 동기화한다.
도 6은 본 발명에 따른 각 라인 카드의 라우팅 프로세서간 내부 연결을 설명하기 위한 개념도이다.
도 6에 도시된 바와 같이, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)는 동일한 라우팅 정보 저장부(311)의 라우팅 정보를 유지하기 위하여, 내부 통신 경로가 연결되어야 한다.
즉, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)간 내부 통신 경로(이하 'VRI'라 칭한다)이 설립되어야 하고, 이러한 통신 경로는 TCP 채널 연결 방식, 멀티캐스팅 채널 연결 방식 및 유니캐스트 채널 연결 방식 등과 같이 신뢰성(reliability) 있는 통신 경로 방식이 사용될 수 있다.
그리고, 라우팅 정보 교환부(313)는 포트부(51)를 통해 연결되는 외부 피어에 대한 라우팅 정보가 변경되면, 타 라인 카드(21~26)로 변경되는 라우팅 정보를 전송하고, 변경된 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다.
또한, 라우팅 정보 교환부(313)는 타 라인 카드(21~26)와 연결된 VRI를 관리한다.
즉, 라우팅 정보 교환부(313)는 새로이 실장되는 라인 카드(21~26)의 라우팅 프로세서(31~36)와 VRI를 설립하고, 라인 카드(21~26)가 탈장되면, 그 라인 카드(21~26)와 설립된 VRI 정보를 잔류시켜, 새로이 실장되는 라인 카드(21~26)와 VRI를 설립할 때 참조할 수 있도록 한다.
이때, 라우팅 정보 교환부(313)는 타 라인 카드(21~26)와 설립되는 VRI를 통 해 교환되는 메시지를 최소화하여, 분산 구조 라우터(100)의 내부 통신 경로인 VRI의 부하를 최소화하는 것이 바람직하다.
그리고, 경로 저장부(334)는 라우팅 정보 교환부(313)가 타 라인 카드(21~26)와 설립한 VRI에 대한 정보가 저장되어 있다.
즉, 경로 저장부(334)에는 분산 구조 라우터(100)에 실장되는 라인 카드(21~26)간 설립되는 VRI 경로 정보 및 해당 라인 카드(21~26)의 구동 유무 정보 등이 저장된다.
도 7은 본 발명의 바람직한 실시예에 따른 분산 구조 라우터의 라우팅 정보 교환부를 설명하기 위한 내부 블록 도면이다.
도 7을 참조하면, 분산 구조 라우터(100)의 라우팅 정보 교환부(313)는, 경로 설정부(331), 라우팅 정보 동기화부(332), RIB 관리부(333) 및 경로 저장부(334)을 포함한다.
경로 설정부(331)는 분산 구조 라우터(100)가 초기 구동되면, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)간 연결되는 VRI를 초기화한다.
즉, 경로 설정부(331)는 분산 구조 라우터(100)의 초기 구동시 또는 새로운 라인 카드(21~26)가 실장되면, 각 라인 카드(21~26)에 저장된 라우팅 정보 저장부(311)의 라우팅 정보를 동기화하기 위하여 설립하는 VRI를 초기화한다.
그리고, 경로 설정부(331)는 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와 VRI를 설립하고, 그 설립되는 VRI에 대한 정보를 경로 저장부(334)에 저장한다.
또한, 경로 설정부(331)는 타 라인 카드(21~26)가 탈장되어 VRI가 종료되거 나, 새로운 라인 카드(21~26)가 실장되어, VRI가 설립되면, 그에 따른 VRI 정보를 경로 저장부(334)에 저장한다.
그리고, 라우팅 정보 동기화부(332)은 분산 구조 라우터(100)가 초기 구동 시 또는 새로운 라인 카드(21~26)가 실장되면, 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와 설립되는 VRI를 통해 라우팅 정보를 동기화한다.
즉, 라우팅 정보 동기화부(332)는 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와 새로운 VRI가 설립되면, 라우팅 정보 요청 메시지를 VRI를 통해 전송하고, 타 라인 카드(21~26)로부터 전송되는 라우팅 정보가 포함된 응답 메시지를 수신한다.
이때, 라우팅 정보 동기화부(332)는 분산 구조 라우터(100)의 내부 통신 경로인 VRI의 부하를 최소화하기 위하여, 포트부(51~56)를 통해 연결되는 외부 피어로부터 전송되는 엔트리 정보에 따라 라우팅 정보만을 전송할 수 있다.
또한, 라우팅 정보 동기화부(332)는 타 라인 카드(21~26)와 라우팅 정보의 동기화가 이루어진 상태에서 외부 피어로부터 변경되는 엔트리 정보가 전송되면, VRI를 통해 외부 피어로부터 전송되는 엔트리 정보에 따른 라우팅 정보를 타 라인 카드(21~26)로 즉시 전송하여, 라우팅 정보의 동기화를 유지하는 것이 바람직하다.
아울러, 라우팅 정보 동기화부(332)는 라우팅 프로세서(31~36)에서 처리하는 라우팅 프로토콜에 따라 라우팅 정보를 주기적으로 타 라인 카드(21~26)로 전송하거나, 변경되는 라우팅 정보가 있으면, 타 라인 카드(21~26)로 전송할 수 있다.
그리고, RIB 관리부(333)는 타 라인 카드(21~26)로부터 전송되는 라우팅 정 보에 따라 라우팅 테이블(134)을 관리한다.
즉, RIB 관리부(333)는 라우팅 정보 동기화부(332)을 통해 라우팅 정보가 수신되면, 그 라우팅 정보에 따라 라우팅 정보 저장부(311)을 생성하거나, 라우팅 정보 저장부(311)가 생성되어 있으면, 수신되는 라우팅 정보를 이용하여 라우팅 정보 저장부(311)를 갱신한다.
도 8은 본 발명의 바람직한 실시예에 따라 분산 구조 라우터의 각 라인 카드간 메시지 교환의 흐름을 설명하기 위한 흐름도이다.
도 8을 참조하여, 분산 구조 라우터(100)에 라인 카드 #2(22)가 실장되어, 외부 피어 #2(62)와 연결되어 있는 상태에서, 라인 카드 #1(21)이 새로이 실장되어, 외부 피어 #1과 연결되는 경우에 대하여 설명한다.
먼저, 분산 구조 라우터(100)의 라인 카드 #2(22)가 외부 피어 #2(62)와 연결되어, 라인 카드 #2(22)의 라우팅 처리부(312)와 외부 피어 #2(62)가 라우팅 정보를 교환하고 있는 상태(S 20)에서 라인 카드 #1(21)이 분산 구조 라우터(100)에 새로이 실장된다(S 21).
그리고, 각 라인 카드(21, 22)의 라우팅 정보 교환부(313)는 각 라인 카드(21, 22)간 내부 통신 경로인 VRI를 설립한다(S 22).
즉, 라우팅 정보 교환부(313)의 경로 설정부(331)는 각 라인 카드(21~26)와 설립되어 있는 VRI를 초기화하고, 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와의 VRI를 설립한다.
그리고, 경로 설정부(334)는 설립된 VRI에 대한 정보를 경로 저장부(334)에 저장한다.
또한, 라인 카드 #1(21)은 라인 카드 #2(22)와 설립된 VRI를 통해 라우팅 정보 저장부(311)에 저장되는 라우팅 정보를 동기화하기 위하여, 라우팅 정보 요청 메시지를 라인 카드 #2(22)로 전송한다(S 23).
즉, 라인 카드 #1(21)의 라우팅 정보 동기화부(332)는 라우팅 정보 요청 메시지를 설립된 VRI를 통해 라인 카드 #2(22)의 라우팅 정보 동기화부(332)로 전송한다.
그리고, 라인 카드 #1(21)의 라우팅 처리부(312)는 포트부(51)를 통해 연결되는 외부 피어 #1(61)로 엔트리 정보 요청 메시지를 전송한다(S 24).
한편, 라인 카드 #2(62)는 라인 카드 #1(61)로부터 전송되는 라우팅 정보 요청 메시지에 따라 라우팅 정보 저장부(311)에 저장된 라우팅 정보를 라인 카드 #1(21)로 전송한다(S 25).
이때, 새로이 실장되는 라인 카드 #1(21)의 라우팅 정보 동기화부(332)이 라우팅 정보 요청 메시지를 라인 카드 #2(22)로 전송하고, 라인 카드 #2(22)의 라우팅 정보 동기화부(332)는 전송되는 라우팅 정보 요청 메시지에 대한 응답으로 라우팅 정보가 포함되는 응답 메시지를 전송하거나, 라인 카드 #2(22)가 새로이 실장되는 라인 카드 #1(21)과 VRI를 설립하면서, 라우팅 정보 저장부(311)에 저장된 라우팅 정보를 전송할 수 있다.
그리고, 라인 카드 #1(21)의 RIB 관리부(333)은 라인 카드 #2(22)로부터 전송되는 라우팅 정보에 따라 라우팅 정보 저장부(311)를 생성/관리한다.
즉, 라인 카드 #1(21)의 RIB 관리부(333)는 라인 카드 #2(22)로부터 라우팅 정보가 전송되면, 라우팅 정보 저장부(311)를 생성하거나, 라우팅 정보 저장부(311)가 생성되어 있으면, 라우팅 정보 저장부(311)에 저장된 라우팅 정보를 갱신하여, 각 라인 카드(21~26)간 라우팅 정보를 동기화한다.
또한, 외부 피어 #1(61)은 라인 카드 #1(21)로부터 전송되는 엔트리 정보 요청 메시지에 대한 응답으로 엔트리 정보가 포함된 응답 메시지(Response message)를 분산 구조 라우터(100)의 라인 카드 #1(21)로 전송한다(S 26).
그리고, 라인 카드 #1(21)의 RIB 관리부(333)은 외부 피어 #1(61)로부터 전송되는 엔트리 정보에 따라 라우팅 정보 저장부(311)의 라우팅 정보를 변경하고, 그 변경되는 라우팅 정보를 라인 카드 #2(22)의 라우팅 정보 동기화부(332)로 전송한다.
또한, 라인 카드 #2(22)의 RIB 관리부(334)는 외부 피어 #2(62)로부터 변경되는 엔트리 정보가 전송되면, 그 엔트리 정보에 따라 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보를 변경하고, 그 변경되는 라우팅 정보를 라인 카드 #1(21)로 전송한다(S 27).
한편, 외부 피어 #2(62)는 라인 카드 #2(22)의 라우팅 프로세서(32)에서 처리하는 라우팅 프로토콜에 따라 주기적으로 엔트리 정보를 라인 카드 #2(22)로 전송하거나, 갱신되는 엔트리 정보가 있으면, 라인 카드 #2(22)로 엔트리 정보를 전송한다(S 28).
또한, 외부 피어 #1(61)은 라인 카드 #1(21)의 라우팅 프로세서(31)에서 처 리하는 라우팅 프로토콜에 따라 주기적으로 엔트리 정보를 라인 카드 #1(21)로 전송하거나, 갱신되는 엔트리 정보가 있으면, 라인 카드 #1(21)로 엔트리 정보를 전송한다(S 29).
그리고, 각 라인 카드(21, 22)의 라우팅 정보 동기화부(332)는 연결되는 외부 피어(61, 62)로부터 갱신되는 엔트리 정보가 전송되면, 라우팅 정보 저장부(311)의 라우팅 정보를 갱신하고, 그 갱신된 라우팅 정보를 타 라인 카드(21, 22)로 전송한다(S 30).
또한, 각 라인 카드(21, 22)의 RIB 관리부(333)는 타 라인 카드(21~26)로부터 라우팅 정보가 전송되면, 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보를 변경하여, 각 라인 카드(21~26)에 저장되어 있는 라우팅 정보가 동일하게 유지될 수 있도록 한다.
그리고, 라인 카드 #1(21)의 라우팅 처리부(312)는 외부 피어 #2(62)에 대한 라우팅 정보가 변경되면, 외부 피어 #1(61)로 변경된 외부 피어 #2(62)의 라우팅 정보를 전송하고(S 31), 라인 카드 #2(22)의 라우팅 처리부(312)는 외부 피어 #1(61)에 대한 라우팅 정보가 변경되면, 외부 피어 #2(62)로 변경되는 외부 피어 #1(61)의 라우팅 정보를 전송한다(S 32).
한편, 외부 피어 #1(61)이 라인 카드 #1(21)과의 연결이 종료되면(S 33), 라인 카드 #1(21)의 라우팅 정보 교환부(313)는 라인 카드 #2(22)로 외부 피어 #1(61)과의 연결이 종료되었음을 알린다(S 34).
그리고, 라인 카드 #1(21)의 라우팅 처리부(312)는 외부 피어 #1(61)과의 연 결이 완전히 종료되었는지 여부를 판단하기 위한 만기 타임을 체크한다(Expire Timeout Timer)(S 35).
또한, 라인 카드 #2(22)의 라우팅 처리부(312)는 외부 피어 #1(61)과의 연결이 종료되어, 변경되는 라우팅 정보를 외부 피어 #2(62)로 전송한다(S 36).
그리고, 라인 카드 #1(21)의 라우팅 처리부(312)는 외부 피어 #1(61)에 대한 만기 타임이 체크되면, 라우팅 정보 저장부(311)에서 외부 피어 #1(61)의 라우팅 정보를 삭제하기 위하여, 만기 정보 제거 타임을 체크한다(Expire Garbage Collection Timer)(S 37).
또한, 라인 카드 #1(21)이 외부 피어 #1(61)에 대한 만기 정보 제거 타임이 체크되면, 라우팅 정보 저장부(311)에서 외부 피어 #1(61)에 대한 라우팅 정보를 삭제하고, 라인 카드 #2(22)로 외부 피어 #1(61)에 대한 라우팅 정보가 삭제되었음을 알린다.
그리고, 라인 카드 #2(22)의 RIB 관리부(333)는 라우팅 정보 저장부(311)에서 외부 피어 #1(61)에 대한 라우팅 정보를 삭제하여, 각 라인 카드(21~26)간 라우팅 정보가 동일하기 유지되도록 한다.
한편, 도 3에 도시된 각 라인 카드(21~26)의 포워딩 처리부(41)는 라우팅 프로세서(31)에서 생성/관리하는 라우팅 정보 저장부(311)에서 포워딩 테이블(412)을 다운로드받아, 외부 피어로부터 포트부(51)를 통해 전송되는 패킷을 포워딩 처리한다.
그리고, 포워딩 관리부(411)는 라우팅 프로세서(31)에서 생성되는 라우팅 정 보 저장부(311)의 라우팅 정보를 기반으로 포워딩 테이블(412)을 생성하고, 라우팅 정보 저장부(311)에 저장된 라우팅 정보가 변경되면, 그에 따라 포워딩 테이블(412)에 저장되는 포워딩 정보를 변경한다.
즉, 포워딩 처리부(41)는 라우팅 프로세서(31)에서 라우팅 프로토콜에 따라 관리하는 라우팅 정보 저장부(311)에 저장되는 라우팅 정보에 따라 포워딩 테이블(412)을 구축/유지하고, 외부 피어로부터 포트부(51)를 통해 패킷이 전송되면, 포워딩 테이블(412)을 룩업하여, 해당 출력 포트로 패킷을 출력한다.
도 9는 본 발명의 바람직한 실시예에 따른 분산 구조 라우터에서 라우팅을 처리하는 방법의 흐름을 설명하기 위한 플로우챠트 도면이다.
도 9를 참조하면, 먼저, 분산 구조 라우터(100)가 초기 구동되면, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)간 VRI를 설립한다(S 40).
이때, 각 라인 카드(21~26)의 경로 설정부(334)는 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와 VRI를 설립하고, 이러한 VRI는, TCP 채널 연결 방식, 멀티캐스팅 채널 연결 방식 및 유니캐스트 채널 연결 방식 등과 같은 방식에 따라 설립할 수 있다.
그리고, 경로 설정부(334)는 타 라인 카드(21~26)의 라우팅 프로세서(31~36)와 설립된 VRI 정보를 경로 저장부(331)에 저장한다(S 41)
그리고, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)는 라우팅 정보를 동기화한다(S 42).
각 라인 카드(21~26)의 라우팅 정보 동기화부(332)는 타 라우팅 프로세서(31~36)와 설립된 VRI를 통해 라우팅 정보 요청 메시지를 전송하고, 그에 대한 응답으로 전송되는 라우팅 정보를 RIB 관리부(333)는 라우팅 정보 저장부(311)에 저장한다.
또한, 라우팅 정보 동기화부(332)는 타 라우팅 프로세서(31~36)로부터 전송되는 라우팅 요청 메시지에 대한 응답으로 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보를 전송한다.
그리고, 각 라인 카드(21~26)의 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보가 동기화된 상태에서 신규 라인 카드(31~36)가 실장되는지 여부를 감지하여(S 43), 신규 라인 카드(21~26)가 실장되면, 각 라인 카드(21~26)는 새로 실장되는 라인 카드(21~26)의 라우팅 프로세서(31~36)와 VRI를 설립하고, 새로 설립되는 VRI 정보를 경로 저장부(334)에 저장한다(S 44).
또한, 신규 라인 카드(21~26)의 라우팅 정보 교환부(313)는 타 라인 카드(21~26)와 VRI가 설립되면, 그 VRI를 통해 라우팅 정보 요청 메시지를 전송하고, 그에 대한 응답으로 전송되는 라우팅 정보를 라우팅 정보 저장부(311)에 저장하여, 각 라인 카드(21~26)와 라우팅 정보를 동일하기 저장한다(S 45).
또한, 신규 라인 카드(21~26)의 라우팅 처리부(312)는 포트부(51)를 통해 연결되는 외부 피어로 엔트리 정보 요청 메시지를 전송하고, 그에 대한 응답으로 전송되는 엔트리 정보에 따른 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다(S 46).
그리고, 신규 라인 카드(21~26)의 라우팅 정보 교환부(313)는 외부 피어의 엔트리 정보에 따라 변경되는 라우팅 정보를 각 라인 카드(21~26)의 라우팅 프로세서(31~36)로 VRI를 통해 전송한다(S 47).
즉, 신규 라인 카드(21~26)의 라우팅 정보 동기화부(332)는 외부 피어로부터 전송되는 엔트리 정보에 따라 변경되는 라우팅 정보를 VRI를 통해 타 라인 카드(21~26)의 라우팅 정보 동기화부(332)로 전송한다.
또한, 각 라인 카드(21~26)의 라우팅 정보 교환부(313)는 신규 라인 카드(21~26)로부터 전송되는 라우팅 정보를 라우팅 정보 저장부(311)에 저장한다(S 48).
그리고, 각 라인 카드(21~26)의 라우팅 프로세서(31~36)는 VRI가 설립되어 있는 타 라인 카드(21~26)가 탈장되는지 여부를 감지하여(S 49), 탈장되는 라인 카드(21~26)가 있으면, 그 라인 카드(21~26)와 설립된 VRI를 종료하고, 해당 라인 카드(21~26)와 VRI가 종료되었음을 경로 저장부(334)에 저장한다(S 50).
즉, 라우팅 프로세서(31~36)의 경로 설정부(331)은 탈장되는 라인 카드(21~26)와 설립된 VRI를 종료하고, 경로 저장부(334)에 해당 라인 카드(21~26)와 설립된 VRI가 종료되었음을 저장한다.
반면, 각 라인 카드(21~26)는 포트부(51~56)를 통해 연결되는 외부 피어로부터 엔트리 정보가 소정 시간동안 전송되지 않으면, 즉 외부 피어와 연결이 종료되는지 여부를 체크하여(S 51), 해당 외부 피어와의 연결이 종료되었다고 판단하여, 타 라인 카드(21~26)의 라우팅 프로세서(31~36)로 해당 외부 피어와의 연결이 종료되었음을 알린다(S 52).
그리고, 라인 카드(21~26)는 해당 외부 피어와의 연결이 안전히 종료되었는지 여부를 판단하기 위하여, 일정 시간동안 해당 외부 피어로부터 메시지가 전송되는지 여부를 체크하고, 일정 시간동안 메시지가 전송되지 않으면, 해당 외부 피어에 대한 라우팅 정보를 라우팅 정보 저장부(311)에서 삭제한다(S 53).
또한, 라인 카드(21~26)의 라우팅 정보 교환부(313)는 라우팅 정보 저장부(311)에서 외부 피어에 대한 라우팅 정보가 삭제되었음을 타 라인 카드(21~26)로 전송하여, 각 라인 카드(21~26)의 라우팅 정보 저장부(311)에 저장된 라우팅 정보가 동일하게 유지되도록 한다.
그리고, 포워딩 관리부(411)는 라우팅 프로세서(31)에서 생성/관리하고 있는 라우팅 정보 저장부(311)에 저장되어 있는 라우팅 정보를 기반으로 포워딩 테이블(412)을 구축하여, 관리한다(S 54).
즉, 포워딩 관리부(411)는 라우팅 프로세서(31)가 외부 피어로부터 전송되는 엔트리 정보를 라우팅 프로토콜에 따라 처리하면서 생성하는 라우팅 정보 저장부(311)에 저장되는 라우팅 정보를 기반으로 포워딩 테이블(412)을 구축한다.
그리고, 라우팅 프로세서(31)가 외부 피어의 엔트리 정보 변경에 따라 라우팅 정보를 변경하면, 그에 따라 변경되는 포워딩 정보를 포워딩 테이블(412)에 저장한다.
그리고, 포워딩 처리부(41)는 외부 피어로부터 패킷이 전송되면, 포워딩 테이블(412)에 저장되어 있는 포워딩 정보를 룩업하여, 해당 출력 포트를 통해 패킷을 출력한다(S 55).
이상에서 본 발명은 기재된 구체 예에 대해서만 상세히 설명하였지만 본 발명의 기술 사상 범위 내에서 다양한 변형 및 수정이 가능함은 당업자에게 있어서 명백한 것이며, 이러한 변형 및 수정이 첨부된 특허청구범위에 속함은 당연한 것이다.
상기한 바와 같이, 본 발명에 따르면, 분산 구조 라우터에서 라우팅 프로토콜의 처리 기능을 다수개의 라인 카드로 분산하고, 각 라인 카드가 네트워크를 통해 연결되는 피어를 관리함으로써, 분산 구조 라우터의 피어 관리 효율을 향상시키는 효과가 있다.
그리고, 각 라인 카드에서 독립적으로 연결되는 피어에 대한 라우팅 프로토콜을 처리하여, 분산 구조 라우터에 연결되는 피어의 개수의 증가에 따라 발생하는 부하를 방지하는 효과가 있다.
또한, 각 라인 카드에서 연결되는 피어에 대한 라우팅 프로토콜을 처리하면서 해당 피어의 최적 경로 프로세싱을 처리하여, 분산 구조 라우터를 포함하는 전체 시스템의 사용 용량을 극대화할 수 있는 효과가 있다.

Claims (22)

  1. 분산 구조 라우터에 있어서,
    다수개의 라인 카드를 포함하되,
    상기 각 라인 카드는, 외부 네트워크를 통해 연결되는 피어로부터 전송되는 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하고, 상기 피어에 대한 라우팅 정보를 타 라인 카드와 설정되는 내부 통신 경로를 통해 교환하여, 상기 각 라인 카드간 라우팅 정보를 동기화하는 라우팅 프로세서; 및
    상기 정보를 기반으로 포워딩 정보를 구축하고, 네트워크로부터 수신되는 패킷을 처리하는 포워딩 처리부를 포함하는 분산 구조 라우터.
  2. 제 1항에 있어서, 상기 라우팅 프로토콜은,
    RIP(Routing Information Protocol), OSPF(Open Shortest Path First), IGRP(Inter-Gateway Routing Protocol), Inergrated IS-IS(Intermediate System to Intermediate System), EGP(Exterior Gateway Protocol) 및 BGP(Border Gateway Protocol) 중 적어도 하나 이상의 프로토콜인 것을 특징으로 하는 분산 구조 라우터.
  3. 제 22항에 있어서, 상기 라우팅 처리부는,
    상기 피어로부터 변경되는 엔트리 정보가 전송되면, 상기 라우팅 프로토콜에 따라 변경되는 엔트리 정보에 따른 최적 라우트를 결정하여, 변경되는 라우팅 정보를 저장하는 것을 특징으로 하는 분산 구조 라우터.
  4. 제 22항에 있어서, 상기 라우팅 처리부는,
    상기 피어로부터 소정 시간동인 엔트리 정보가 전송되지 않으면, 상기 라우팅 정보 저장부에서 상기 피어에 대한 라우팅 정보를 삭제하는 것을 특징으로 하는 분산 구조 라우터.
  5. 제 22항에 있어서, 상기 라우팅 처리부는,
    상기 피어가 연결되면, 엔트리 정보 요청 메시지를 전송하고, 상기 요청 메시지에 대한 응답으로 엔트리 정보를 수신하는 메시지 처리부;
    상기 메시지 처리부를 통해 수신되는 엔트리 정보와, 설정된 라우팅 프로토콜에 따라 상기 피어의 최적 라우트를 결정하여, 라우팅 정보를 상기 라우팅 정보 저장부에 저장하는 라우트 결정부를 포함하는 분산 구조 라우터.
  6. 제 5항에 있어서, 상기 메시지 처리부는,
    소정 주기로 라우팅 정보를 전송하거나, 변경되는 라우팅 정보가 발생하면, 라우팅 정보를 전송하는 것을 특징으로 하는 분산 구조 라우터.
  7. 제 5항에 있어서, 상기 라우트 결정부는,
    상기 피어로부터 변경되는 엔트리 정보가 전송되면, 상기 변경되는 엔트리 정보에 따른 최적 라우트를 결정하여, 변경되는 라우팅 정보를 저장하는 것을 특징으로 하는 분산 구조 라우터.
  8. 제 22항에 있어서, 상기 라우팅 정보 교환부는,
    타 라인 카드와 내부 통신 경로를 설정하는 경로 설정부;
    상기 경로 설정부가 설정하는 내부 통신 경로에 대한 정보를 저장하는 경로 저장부;
    상기 경로 설정부에서 설정되는 내부 통신 경로를 통해 타 라인 카드와 라우팅 정보를 교환하여, 타 라인 카드에 저장된 라우팅 정보와 동일한 라우팅 정보를 상기 라우팅 정보 저장부에 저장하는 라우팅 정보 동기화부를 포함하는 분산 구조 라우터.
  9. 제 8항에 있어서, 상기 경로 저장부는,
    상기 경로 설정부가 설정하는 내부 통신 경로로 연결되는 라인 카드 정보, 상기 라인 카드와 내부 통신 경로 연결 유무 정보 및 상기 내부 통신 경로 상태 정보 중 적어도 하나 이상의 정보를 저장하는 것을 특징으로 하는 분산 구조 라우터.
  10. 제 8항에 있어서, 상기 경로 설정부는,
    상기 분산 구조 라우터에서 타 라인 카드가 탈장되면, 설정된 내부 통신 경로를 종료하고, 그 내부 통신 경로의 종료를 상기 경로 저장부에 저장하는 것을 특징으로 하는 분산 구조 라우터.
  11. 제 8항에 있어서, 상기 라우팅 정보 동기화부는,
    상기 라인 카드와 연결된 피어의 라우팅 정보가 변경되면, 상기 내부 통신 경로를 통해 타 라인 카드로 변경된 라우팅 정보를 전송하고, 타 라인 카드로부터 변경되는 라우팅 정보가 수신되면, 상기 저장된 라우팅 정보를 갱신하는 것을 특징으로 하는 분산 구조 라우터.
  12. 제 8항에 있어서, 상기 라우팅 정보 동기화부는,
    타 라인 카드가 탈장되면, 상기 라인 카드와 연결되는 피어에 대한 라우팅 정보를 상기 라우팅 정보 저장부에서 삭제하고, 상기 라우팅 정보가 삭제되었음을 타 라인 카드로 알리는 것을 특징으로 하는 분산 구조 라우터.
  13. 라우터에 있어서,
    네트워크를 통해 피어와 연결되고, 상기 피어로부터 패킷 및 엔트리 정보가 포함된 메시지를 수신하고, 상기 패킷이 목적지로 전송될 수 있도록 출력하는 다수개의 포트;
    상기 각 포트를 통해 수신되는 패킷을 해당 출력 포트로 출력되도록 스위칭하는 스위치 패브릭;
    상기 각 입력 포트를 통해 수신되는 상기 메시지에서 상기 피어의 엔트리 정보를 추출하고, 상기 엔트리 정보와, 기설정되는 라우팅 프로토콜에 따라 처리하여, 최적 라우트를 결정하고, 상기 피어로부터 수신되는 패킷이 상기 최적 라우트에 따라 해당 출력 포트를 통해 출력되도록 하는 적어도 하나 이상의 라인 카드를 포함하는 분산 구조 라우터.
  14. 제 13항에 있어서, 상기 각 라인 카드는,
    상기 피어에 대한 라우팅 정보를 저장하며, 상기 각 입력 포트를 통해 수신되는 엔트리 정보에 따라 상기 피어의 최적 라우트를 결정하고, 상기 최적 라우트에 따른 라우팅 정보를 상기 라우팅 정보 저장부에 저장하고, 타 라인 카드와 상기 라우팅 정보 저장부에 저장된 라우팅 정보를 교환하여 동기화하는 라우팅 프로세서;
    상기 라우팅 정보 저장부에 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하고, 상기 각 포트를 통해 수신되는 패킷의 출력 포트를 상기 포워딩 정보에서 서치하여, 해당 출력 포트로 상기 패킷을 출력하는 포워딩 처리부를 포함하는 분산 구조 라우터.
  15. 적어도 하나 이상의 라인 카드를 구비하는 분산 구조 라우터에서 라우팅 프로토콜을 처리하는 방법에 있어서,
    상기 각 라인 카드가 네트워크로 연결되는 피어의 라우팅 정보를 라우팅 프로토콜에 따라 생성하여 저장하는 단계;
    상기 분산 구조 라우터의 각 라인 카드간 내부 통신 경로를 설정하고, 상기 설정된 내부 통신 경로를 통해 상기 각 라인 카드에 저장되는 라우팅 정보를 교환하여, 동기화하는 단계;
    상기 각 라인 카드가 변경되는 라우팅 정보가 있으면, 상기 내부 통신 경로를 통해 타 라인 카드로 전송하여, 라우팅 정보의 동기화를 유지하는 단계;
    상기 각 라인 카드가 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하는 단계;
    상기 각 라인 카드가 패킷이 수신되면, 상기 구축된 포워딩 정보에 따라 포워딩 처리를 수행하는 단계를 포함하는 분산 구조 라우터의 라우팅 처리 방법.
  16. 제 15항에 있어서,
    상기 각 라인 카드가 피어와 연결이 종료되면, 상기 피어에 대한 라우팅 정보를 삭제하고, 상기 라우팅 정보 삭제를 타 라인 카드로 알리하는 단계;
    상기 각 라인 카드가 신규 피어와 연결되면, 상기 피어의 엔트리 정보와, 라우팅 프로토콜에 따른 최적 라우트를 결정하여, 신규 라우팅 정보를 저장하고, 타 라인 카드로 상기 신규 라우팅 정보를 전송하는 단계를 더 포함하는 분산 구조 라우터의 라우팅 처리 방법.
  17. 제 15항에 있어서,
    임의 라인 카드가 신규 실장되면, 상기 각 라인 카드와 내부 통신 경로를 설정하고, 내부 통신 경로 정보를 저장하는 단계;
    상기 각 라인 카드가 연결되는 피어의 엔트리 정보와 라우팅 프로토콜에 따른 최적 라우트를 결정하여, 라우팅 정보를 저장하고, 상기 라우팅 정보를 상기 내부 통신 경로를 통해 타 라인 카드로 전송하는 단계;
    임의 라인 카드가 탈장되면, 상기 라인 카드와 내부 통신 경로를 종료하고, 해당 라인 카드와의 내부 통신 경로가 종료되었음을 저장하는 단계를 더 포함하는 분산 구조 라우터의 라우팅 처리 방법.
  18. 제 15항에 있어서, 상기 라우팅 정보 전송은,
    소정 주기로 라우팅 정보를 전송하거나, 변경되는 라우팅 정보가 발생하면, 라우팅 정보를 전송하는 것을 특징으로 하는 분산 구조 라우터의 라우팅 처리 방법.
  19. 제 15항에 있어서, 상기 라우팅 프로토콜은,
    RIP(Routing Information Protocol), OSPF(Open Shortest Path First), IGRP(Inter-Gateway Routing Protocol), Inergrated IS-IS(Intermediate System to Intermediate System), EGP(Exterior Gateway Protocol) 및 BGP(Border Gateway Protocol) 중 적어도 하나 이상의 프로토콜인 것을 특징으로 하는 분산 구조 라우 터의 라우팅 처리 방법.
  20. 적어도 하나 이상의 라인 카드를 구비하는 분산 구조 라우터에서 라우팅 프로토콜을 처리하는 방법에 있어서,
    상기 각 라인 카드가 네트워크로 연결되는 피어의 라우팅 정보를 라우팅 프로토콜에 따라 생성하여 저장하는 단계;
    상기 분산 구조 라우터의 각 라인 카드간 내부 통신 경로를 설립하고, 상기 라인 카드가 상기 내부 통신 경로를 통해 라우팅 정보를 교환하여, 라우팅 정보를 동기화하는 단계;
    임의 라인 카드에 네트워크를 통해 피어가 연결되면, 상기 피어의 엔트리 정보를 설정되는 라우팅 프로토콜에 따라 처리하여, 최적 라우트를 결정하고, 그에 따른 라우팅 정보를 타 라인 카드로 상기 내부 통신 경로를 통해 전송하는 단계;
    임의 라인 카드가 피어와 연결이 종료되면, 상기 피어에 대한 라우팅 정보를 삭제하고, 상기 라우팅 정보 삭제를 타 라인 카드로 전송하는 단계;
    임의 라인 카드에 신규 피어와 연결되면, 상기 피어의 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하여, 신규 라우팅 정보를 저장하고, 타 라인 카드로 상기 신규 라우팅 정보를 전송하는 단계;
    상기 각 라인 카드가 저장된 라우팅 정보를 기반으로 포워딩 정보를 구축하고, 패킷이 수신되면, 상기 구축된 포워딩 정보에 따라 포워딩 처리를 수행하는 단 계를 포함하는 분산 구조 라우터의 라우팅 처리 방법.
  21. 제 20항에 있어서, 상기 라우팅 프로토콜은,
    RIP(Routing Information Protocol), OSPF(Open Shortest Path First), IGRP(Inter-Gateway Routing Protocol), Inergrated IS-IS(Intermediate System to Intermediate System), EGP(Exterior Gateway Protocol) 및 BGP(Border Gateway Protocol) 중 적어도 하나 이상의 프로토콜인 것을 특징으로 하는 분산 구조 라우터의 라우팅 처리 방법.
  22. 제 1 항에 있어서, 상기 라우팅 프로세서는,
    상기 피어에 대한 라우팅 정보를 저장하는 라우팅 정보 저장부;
    상기 피어로부터 전송되는 엔트리 정보를 설정된 라우팅 프로토콜에 따라 최적 라우트를 결정하여, 상기 피어에 대한 라우팅 정보를 상기 라우팅 정보 저장부에 저장하는 라우팅 처리부; 및
    상기 타 라인 카드와 내부 통신 경로를 설정하고, 상기 내부 통신 경로를 통해 상기 타 라인 카드와 라우팅 정보를 교환하여, 상기 각 라인 카드간 라우팅 정보를 동기화하는 라우팅 정보 교환부를 포함하는 분산 구조 라우터.
KR20040006791A 2004-02-02 2004-02-02 분산 구조 라우터의 라우팅 처리 방법 및 그 장치 KR100591107B1 (ko)

Priority Applications (4)

Application Number Priority Date Filing Date Title
KR20040006791A KR100591107B1 (ko) 2004-02-02 2004-02-02 분산 구조 라우터의 라우팅 처리 방법 및 그 장치
US11/013,802 US20050169281A1 (en) 2004-02-02 2004-12-17 Distributed router
JP2005019645A JP4095069B2 (ja) 2004-02-02 2005-01-27 分散構造ルータ及び分散構造ルータのルーティング処理方法
CNA2005100063001A CN1652528A (zh) 2004-02-02 2005-02-02 分布式路由器

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR20040006791A KR100591107B1 (ko) 2004-02-02 2004-02-02 분산 구조 라우터의 라우팅 처리 방법 및 그 장치

Publications (2)

Publication Number Publication Date
KR20050078606A KR20050078606A (ko) 2005-08-05
KR100591107B1 true KR100591107B1 (ko) 2006-06-19

Family

ID=34806086

Family Applications (1)

Application Number Title Priority Date Filing Date
KR20040006791A KR100591107B1 (ko) 2004-02-02 2004-02-02 분산 구조 라우터의 라우팅 처리 방법 및 그 장치

Country Status (4)

Country Link
US (1) US20050169281A1 (ko)
JP (1) JP4095069B2 (ko)
KR (1) KR100591107B1 (ko)
CN (1) CN1652528A (ko)

Families Citing this family (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7200144B2 (en) * 2001-10-18 2007-04-03 Qlogic, Corp. Router and methods using network addresses for virtualization
US7447197B2 (en) * 2001-10-18 2008-11-04 Qlogic, Corporation System and method of providing network node services
US20040022200A1 (en) * 2002-07-31 2004-02-05 Sun Microsystems, Inc. Method, system, and program for providing information on components within a network
US20080008202A1 (en) * 2002-10-31 2008-01-10 Terrell William C Router with routing processors and methods for virtualization
US9032095B1 (en) 2004-01-06 2015-05-12 Juniper Networks, Inc. Routing device having multiple logical routers
KR100746858B1 (ko) * 2005-12-09 2007-08-07 한국전자통신연구원 IPv6 패킷 포워딩이 가능한 라인카드에서의 인터페이스관리 방법 및 장치
CN100423514C (zh) * 2006-06-01 2008-10-01 杭州华三通信技术有限公司 分布式设备中地址解析协议数据同步的方法
JP4638849B2 (ja) * 2006-08-25 2011-02-23 日本電信電話株式会社 機能分散型通信装置および経路制御方法
KR100845426B1 (ko) * 2006-12-07 2008-07-10 한국전자통신연구원 분산 제어 환경에서의 이벤트 기반의 가용성 보장 운용 서비스 장치 및 방법
JP2008182326A (ja) * 2007-01-23 2008-08-07 Sii Network Systems Kk ラインカード装置、スイッチ装置、及び、経路情報学習方法
JP4630298B2 (ja) * 2007-02-22 2011-02-09 日本電信電話株式会社 機能分散型通信装置、構成要素結合制御方法、およびプログラム
US8625592B2 (en) * 2008-02-26 2014-01-07 Cisco Technology, Inc. Blade switch with scalable interfaces
KR20120004993A (ko) * 2009-03-18 2012-01-13 록스타 비드코 엘피 입력/출력 데이터 전달용의 논리적 네트워크 계층을 제공하기 위한 방법 및 시스템
US8369345B1 (en) * 2009-11-13 2013-02-05 Juniper Networks, Inc. Multi-router system having shared network interfaces
US8638791B2 (en) * 2009-11-24 2014-01-28 Verizon Patent And Licensing Inc. Heterogeneous forwarding information bases in line cards
WO2011083565A1 (ja) * 2010-01-05 2011-07-14 三菱電機株式会社 ルーチング情報生成装置、ルーチング情報生成方法およびルーチング情報生成プログラム
CN102907057B (zh) * 2010-05-20 2015-12-02 惠普发展公司,有限责任合伙企业 网络装置中的交换
WO2012000557A1 (en) * 2010-07-01 2012-01-05 Telefonaktiebolaget Lm Ericsson (Publ) Method and apparatus for dissemination of information between routers
US9009518B2 (en) * 2010-07-29 2015-04-14 Cisco Technology, Inc. Method and apparatus for conveying and reproducing multiple independent timebases using a shared reference clock, clock snapshots and a packet network
US9338055B2 (en) * 2013-03-15 2016-05-10 Cisco Technology, Inc. Virtual router upgrade via graceful restart
US20150012679A1 (en) * 2013-07-03 2015-01-08 Iii Holdings 2, Llc Implementing remote transaction functionalities between data processing nodes of a switched interconnect fabric
JP2015015640A (ja) * 2013-07-05 2015-01-22 株式会社日立製作所 通信システム、プロトコル処理計算機、及び通信方法
CN108092902A (zh) * 2016-11-23 2018-05-29 镇江常畅光伏电子有限公司 一种标记交换路由器
CN108092900A (zh) * 2016-11-23 2018-05-29 镇江常畅光伏电子有限公司 一种多端口路由器
US10608841B2 (en) * 2017-07-28 2020-03-31 Level 3 Communications, Llc Autonomous system bridge connecting in a telecommunications network
PT3698520T (pt) * 2017-10-17 2024-03-27 Drivenets Ltd Sistema de roteamento de comunicação
US10642650B2 (en) * 2017-12-13 2020-05-05 Juniper Networks, Inc. Multi-threaded route processing
CN109587061B (zh) * 2018-11-08 2022-04-22 华为技术有限公司 一种路由处理的方法、装置及设备
US11502946B2 (en) 2020-03-10 2022-11-15 Juniper Networks, Inc. Distributed label assignment for labeled routing protocol routes
US11356369B1 (en) 2020-03-31 2022-06-07 Juniper Networks, Inc. Border gateway protocol update packing for a distributed routing information base
US11561823B1 (en) 2020-05-12 2023-01-24 Juniper Networks, Inc. Lockless management of immutable objects by multi-threaded processes using multiple counters
US11762710B2 (en) 2020-06-23 2023-09-19 Juniper Networks, Inc. Multithreaded route processing for routing information display

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003008631A (ja) 2001-06-22 2003-01-10 Nec Corp データ交換装置におけるルーティング処理システム
KR20030083864A (ko) * 2002-04-22 2003-11-01 한국전자통신연구원 고속 라우터 시스템에서 분산 포워딩 테이블 처리방법
KR20030087434A (ko) * 2002-05-10 2003-11-14 한국전자통신연구원 고속 라우터에서 분산 포워딩을 위한 테이블 관리 방법
US20040006640A1 (en) 2002-07-03 2004-01-08 Inderieden Daniel W. Notification to routing protocols of changes to routing information base

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6078963A (en) * 1998-01-16 2000-06-20 At&T Corp. Router with de-centralized processing using intelligent ports
US6879559B1 (en) * 2000-10-31 2005-04-12 Chiaro Networks, Ltd. Router line card protection using one-for-N redundancy
US7035202B2 (en) * 2001-03-16 2006-04-25 Juniper Networks, Inc. Network routing using link failure information
US7139242B2 (en) * 2001-03-28 2006-11-21 Proficient Networks, Inc. Methods, apparatuses and systems facilitating deployment, support and configuration of network routing policies
US7054311B2 (en) * 2001-07-27 2006-05-30 4198638 Canada Inc. Methods and apparatus for storage and processing of routing information
US7035256B1 (en) * 2001-10-31 2006-04-25 Redback Networks Inc. Method and apparatus for a routing information base
KR100474677B1 (ko) * 2002-04-18 2005-03-08 삼성전자주식회사 분산 구조 라우터에서 라우팅 프로토콜 모듈의 결함 발생검사방법
US6948040B2 (en) * 2002-05-17 2005-09-20 Samsung Electronics Co., Ltd. System and method for synchronizing a plurality of processors in a processor array
IL152676A0 (en) * 2002-11-06 2003-06-24 Teracross Ltd Method and apparatus for high performance single block scheduling in distributed systems
US6850492B2 (en) * 2002-11-22 2005-02-01 Nokia Corporation Method and system for enabling a route and flow table update in a distributed routing platform
US7023808B2 (en) * 2003-12-23 2006-04-04 Cisco Technology, Inc. System and method for distributing route selection in an implementation of a routing protocol

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2003008631A (ja) 2001-06-22 2003-01-10 Nec Corp データ交換装置におけるルーティング処理システム
KR20030083864A (ko) * 2002-04-22 2003-11-01 한국전자통신연구원 고속 라우터 시스템에서 분산 포워딩 테이블 처리방법
KR20030087434A (ko) * 2002-05-10 2003-11-14 한국전자통신연구원 고속 라우터에서 분산 포워딩을 위한 테이블 관리 방법
US20040006640A1 (en) 2002-07-03 2004-01-08 Inderieden Daniel W. Notification to routing protocols of changes to routing information base

Also Published As

Publication number Publication date
CN1652528A (zh) 2005-08-10
US20050169281A1 (en) 2005-08-04
JP4095069B2 (ja) 2008-06-04
KR20050078606A (ko) 2005-08-05
JP2005218106A (ja) 2005-08-11

Similar Documents

Publication Publication Date Title
KR100591107B1 (ko) 분산 구조 라우터의 라우팅 처리 방법 및 그 장치
CN1849783B (zh) 用于实现边界网关协议(bgp)的分布式软件体系结构
US7573811B2 (en) Network transparent OSPF-TE failover
US7437476B2 (en) Optimizing flooding of information in link-state routing protocol
US8243588B2 (en) Disaster recovery for active-standby data center using route health and BGP
US7835303B2 (en) Packet-switched network topology tracking method and system
US6049524A (en) Multiplex router device comprising a function for controlling a traffic occurrence at the time of alteration process of a plurality of router calculation units
US7974315B2 (en) Method for implementing synchronization of link state database, router, line card and master board
US6823395B1 (en) Arrangement and method relating to routing in a network
US8351438B2 (en) Flooding-based routing protocol having database pruning and rate-controlled state refresh
JP2006135970A (ja) SoftRouter動的バインディング・プロトコル
US7388862B2 (en) Technique for notifying EIGRP neighbors when destroying adjacencies in a computer network
KR20060092982A (ko) 소프트라우터 프로토콜 장애 극복들
CN101455030A (zh) 动态共享风险节点组(srng)成员发现
US7391730B1 (en) System and method for synchronizing link state databases in a network environment
US20230010837A1 (en) Fault diagnosis method and apparatus thereof
US7639680B1 (en) Out of band data base synchronization for OSPF
US20120166658A1 (en) Gmpls network-based inter-domain interface apparatus and method
JP3773907B2 (ja) データ中継方法、データ中継装置およびデータ中継システム
KR100560753B1 (ko) 분산 구조 라우터의 라우터 정보 관리 방법 및 그 장치
JP2003258877A (ja) ルータ装置及びルーティング方法
JP3764149B2 (ja) データ中継方法、経路情報管理装置、データ中継装置およびデータ中継システム
KR100590877B1 (ko) 분산 처리 구조 라우터의 라우터 정보 처리 방법 및 그 장치
JP2010028464A (ja) 通信システム及び転送装置
CN102104540A (zh) As号更新的方法及bgp发言者

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20130530

Year of fee payment: 8

FPAY Annual fee payment

Payment date: 20140529

Year of fee payment: 9

FPAY Annual fee payment

Payment date: 20150528

Year of fee payment: 10

LAPS Lapse due to unpaid annual fee