상호 연결 네트워크 설계

interconnection network병렬 시스템에서는 모든 소스 노드에서 원하는 대상 노드로 정보를 전송합니다. 이 작업은 가능한 한 짧은 대기 시간으로 완료해야합니다. 많은 수의 이러한 전송이 동시에 발생하도록해야합니다. 또한 나머지 기계의 비용에 비해 저렴해야합니다.

네트워크는 링크와 스위치로 구성되어 소스 노드에서 대상 노드로 정보를 보내는 데 도움이됩니다. 네트워크는 토폴로지, 라우팅 알고리즘, 스위칭 전략 및 흐름 제어 메커니즘에 의해 지정됩니다.

조직 구조

상호 연결 네트워크는 다음 세 가지 기본 구성 요소로 구성됩니다

  • Links− 링크는 스위치 또는 네트워크 인터페이스 포트에 연결된 각 끝에 커넥터가있는 하나 이상의 광섬유 또는 전선으로 구성된 케이블입니다. 이를 통해 아날로그 신호가 한쪽 끝에서 전송되고 다른 쪽 끝에서 수신되어 원래의 디지털 정보 스트림을 얻습니다.

  • Switches− 스위치는 입력 및 출력 포트 세트, 모든 입력을 모든 출력에 연결하는 내부 "크로스바", 내부 버퍼링 및 각 시점에서 입력-출력 연결에 영향을주는 제어 로직으로 구성됩니다. 일반적으로 입력 포트의 수는 출력 포트의 수와 같습니다.

  • Network Interfaces− 네트워크 인터페이스는 스위치 노드와 매우 다르게 작동하며 특수 링크를 통해 연결될 수 있습니다. 네트워크 인터페이스는 패킷 형식을 지정하고 라우팅 및 제어 정보를 구성합니다. 스위치에 비해 입력 및 출력 버퍼링이있을 수 있습니다. 종단 간 오류 검사 및 흐름 제어를 수행 할 수 있습니다. 따라서 비용은 처리 복잡성, 저장 용량 및 포트 수의 영향을받습니다.

상호 연결 네트워크

상호 연결 네트워크는 스위칭 요소로 구성됩니다. 토폴로지는 개별 스위치를 프로세서, 메모리 및 기타 스위치와 같은 다른 요소에 연결하는 패턴입니다. 네트워크를 통해 병렬 시스템의 프로세서간에 데이터를 교환 할 수 있습니다.

  • Direct connection networks− 직접 네트워크는 인접 노드 사이에 지점 간 연결이 있습니다. 이러한 네트워크는 정적이므로 지점 간 연결이 고정되어 있습니다. 직접 네트워크의 몇 가지 예는 링, 메시 및 큐브입니다.

  • Indirect connection networks− 간접 네트워크에는 고정 된 이웃이 없습니다. 통신 토폴로지는 애플리케이션 요구 사항에 따라 동적으로 변경 될 수 있습니다. 간접 네트워크는 버스 네트워크, 다단계 네트워크 및 크로스바 스위치의 세 부분으로 나눌 수 있습니다.

    • Bus networks− 버스 네트워크는 여러 리소스가 연결된 여러 비트 라인으로 구성됩니다. 버스가 데이터와 주소에 동일한 물리적 라인을 사용하면 데이터와 주소 라인이 시간 다중화됩니다. 버스에 여러 버스 마스터가 연결되어있는 경우 중재자가 필요합니다.

    • Multistage networks− 다단계 네트워크는 여러 단계의 스위치로 구성됩니다. 특정 단계 간 연결 패턴 (ISC)을 사용하여 연결된 'axb'스위치로 구성됩니다. 작은 2x2 스위치 요소는 많은 다단계 네트워크에서 일반적으로 선택됩니다. 단계 수에 따라 네트워크 지연이 결정됩니다. 서로 다른 단계 간 연결 패턴을 선택하여 다양한 유형의 다단계 네트워크를 만들 수 있습니다.

    • Crossbar switches− 크로스바 스위치에는 연결을 생성하거나 끊기 위해 켜고 끌 수있는 간단한 스위치 요소 매트릭스가 포함되어 있습니다. 매트릭스의 스위치 요소를 켜면 프로세서와 메모리가 연결될 수 있습니다. 크로스바 스위치는 차단되지 않습니다. 즉, 모든 통신 순열이 차단없이 수행 될 수 있습니다.

네트워크 토폴로지에서 디자인 트레이드 오프 평가

주요 관심사가 라우팅 거리 인 경우 치수를 최대화하고 하이퍼 큐브를 만들어야합니다. 저장 후 전달 라우팅에서 스위치의 정도와 링크의 수는 중요한 비용 요소가 아니고 링크의 수 또는 스위치의 정도가 주요 비용이라고 가정하면 치수를 최소화하고 메쉬를 만들어야합니다. 세워짐.

각 네트워크에 대한 최악의 트래픽 패턴에서는 모든 경로가 짧은 고차원 네트워크를 사용하는 것이 좋습니다. 각 노드가 하나 또는 두 개의 인접 이웃과 만 통신하는 패턴에서는 실제로 사용되는 차원 중 몇 개만 사용되므로 저 차원 네트워크를 사용하는 것이 좋습니다.

라우팅

네트워크의 라우팅 알고리즘은 소스에서 목적지까지의 가능한 경로 중 경로로 사용되는 경로와 각 특정 패킷이 따르는 경로를 결정하는 방법을 결정합니다. 차원 순서 라우팅은 각 소스에서 각 대상까지 정확히 하나의 경로가 있도록 올바른 경로 세트를 제한합니다. 먼저 고차원 차원에서 올바른 거리를 이동 한 다음 다음 차원 등으로 이동하여 얻은 것입니다.

라우팅 메커니즘

산술, 소스 기반 포트 선택 및 테이블 조회는 고속 스위치가 패킷 헤더의 정보에서 출력 채널을 결정하는 데 사용하는 세 가지 메커니즘입니다. 이러한 모든 메커니즘은 기존의 LAN 및 WAN 라우터에 구현 된 일반적인 라우팅 계산보다 간단합니다. 병렬 컴퓨터 네트워크에서 스위치는 모든주기의 모든 입력에 대해 라우팅 결정을 내려야하므로 메커니즘은 간단하고 빠르 야합니다.

결정적 라우팅

라우팅 알고리즘은 메시지가 사용하는 경로가 네트워크의 다른 트래픽이 아니라 원본과 대상에 의해서만 결정되는 경우 결정적입니다. 라우팅 알고리즘이 대상에 대한 최단 경로 만 선택하는 경우 최소값이고 그렇지 않으면 최소값이 아닙니다.

교착 상태 자유

교착 상태는 다양한 상황에서 발생할 수 있습니다. 두 노드가 서로 데이터를 보내려고 시도하고 각 노드가 수신하기 전에 전송을 시작하면 'head-on'교착 상태가 발생할 수 있습니다. 교착 상태의 또 다른 경우는 네트워크 내의 리소스를두고 경쟁하는 여러 메시지가있을 때 발생합니다.

네트워크에 교착 상태가 없음을 입증하는 기본 기술은 메시지가 네트워크를 통해 이동하는 결과로 채널간에 발생할 수있는 종속성을 제거하고 전체 채널 종속성 그래프에주기가 없음을 표시하는 것입니다. 따라서 교착 상태로 이어질 수있는 트래픽 패턴이 없습니다. 이를 수행하는 일반적인 방법은 모든 경로가 특정 증가 또는 감소 시퀀스를 따르도록 채널 리소스에 번호를 매겨 종속성주기가 발생하지 않도록하는 것입니다.

스위치 디자인

네트워크 설계는 스위치 설계와 스위치가 함께 연결되는 방식에 따라 다릅니다. 스위치의 정도, 내부 라우팅 메커니즘 및 내부 버퍼링은 지원할 수있는 토폴로지와 구현할 수있는 라우팅 알고리즘을 결정합니다. 컴퓨터 시스템의 다른 하드웨어 구성 요소와 마찬가지로 네트워크 스위치에는 데이터 경로, 제어 및 저장소가 포함되어 있습니다.

항구

총 핀 수는 실제로 총 입력 및 출력 포트 수에 채널 폭을 곱한 값입니다. 칩의 경계가 면적에 비해 천천히 증가함에 따라 스위치는 핀이 제한되는 경향이 있습니다.

내부 데이터 경로

데이터 경로는 각 입력 포트 세트와 모든 출력 포트 간의 연결입니다. 일반적으로 내부 크로스 바라고합니다. 비 차단 크로스바는 각 입력 포트를 모든 순열에서 동시에 별개의 출력에 연결할 수있는 크로스바입니다.

채널 버퍼

스위치 내의 버퍼 스토리지 구성은 스위치 성능에 중요한 영향을 미칩니다. 기존 라우터 및 스위치는 스위치 패브릭 외부에 큰 SRAM 또는 DRAM 버퍼를 갖는 경향이있는 반면, VLSI 스위치에서는 버퍼링이 스위치 내부에 있으며 데이터 경로 및 제어 섹션과 동일한 실리콘 예산에서 나옵니다. 칩 크기와 밀도가 증가함에 따라 더 많은 버퍼링을 사용할 수 있고 네트워크 설계자는 더 많은 옵션을 사용할 수 있지만 여전히 버퍼 공간이 가장 중요한 선택이며 그 구성이 중요합니다.

흐름 제어

네트워크의 여러 데이터 흐름이 동일한 공유 네트워크 리소스를 동시에 사용하려고하면 이러한 흐름을 제어하기 위해 몇 가지 조치를 취해야합니다. 데이터 손실을 원하지 않는 경우 일부 흐름은 차단하고 다른 흐름은 진행해야합니다.

흐름 제어의 문제는 모든 네트워크와 여러 수준에서 발생합니다. 그러나 병렬 컴퓨터 네트워크에서 로컬 및 광역 네트워크와 질적으로 다릅니다. 병렬 컴퓨터에서 네트워크 트래픽은 버스를 통과하는 트래픽만큼 정확하게 전달되어야하며 매우 짧은 시간에 매우 많은 수의 병렬 흐름이 있습니다.