채널 모델 개요
WCF(Windows Communication Foundation) 채널 스택은 메시지를 처리하는 하나 이상의 채널로 계층화된 통신 스택입니다. 스택의 맨 아래에는 채널 스택을 TCP, HTTP, SMTP 및 기타 다른 유형의 전송과 같은 기본 전송에 적용하는 전송 채널이 있습니다. 채널은 메시지를 보내고 받기 위한 하위 수준의 프로그래밍 모델을 제공합니다. 이러한 프로그래밍 모델에서는 몇 가지 인터페이스와 총체적으로 WCF 채널 모델이라고 하는 기타 형식을 사용합니다. 이 항목에서는 채널 셰이프, 서비스에서의 기본 채널 수신기 생성 및 클라이언트에서의 채널 팩터리 생성에 대해 설명합니다.
채널 스택
WCF 끝점은 채널 스택이라고 하는 통신 스택을 사용하여 세계와 통신합니다. 다음 다이어그램에서는 채널 스택을 TCP/IP 등의 다른 통신 스택과 비교합니다.
우선 유사점은 두 경우 모두 스택의 각 계층이 해당 계층 아래 세계에 대한 일부 추상화를 제공하고, 해당 추상화는 그 바로 위 계층에만 노출된다는 점입니다. 각 계층에서는 바로 아래 계층에 대한 추상화만 사용합니다. 또한 두 경우 모두, 두 스택이 통신할 때 각 계층은 상대 스택의 해당 계층과 통신합니다. 예를 들어 IP 계층은 IP 계층끼리, TCP 계층은 TCP 계층끼리 통신합니다.
차이점은 TCP 스택은 실제 네트워크에 대한 추상화를 제공하도록 디자인된 반면, 채널 스택은 메시지 전달 방법(즉, 전송)뿐 아니라 메시지 내용 또는 통신에 사용되는 프로토콜 등의 기타 기능(전송은 해당되지만 그 이상은 아님)에 대해서도 추상화를 제공하도록 디자인되었습니다. 예를 들어 신뢰할 수 있는 세션 바인딩 요소는 채널 스택의 일부지만 전송 아래에 있거나 전송 자체는 아닙니다. 이러한 추상화는 스택의 맨 아래 채널에게 기본 전송 프로토콜을 채널 스택 아키텍처에 적용하도록 요구한 다음, 안정성 보장 및 보안과 같은 통신 기능을 제공하기 위해 스택의 상위 채널을 사용하는 방식으로 이루어집니다.
메시지는 Message 개체와 같은 통신 스택을 통해 이동합니다. 위 그림과 같이 맨 아래 채널을 전송 채널이라고 하며, 이 채널을 통해 메시지를 다른 상대방과 주고 받게 됩니다. 또한 Message 개체를 다른 상대방과 통신하기 위한 형식으로 변환하기도 합니다. 이 전송 채널 위에는 안정된 전달 보장과 같은 통신 기능을 제공하는 여러 프로토콜 채널이 있을 수 있습니다. 프로토콜 채널은 Message 개체의 형태로 프로토콜 채널을 통해 이동하는 메시지를 바탕으로 작동합니다. 그리고 일반적으로 헤더 추가 또는 본문 암호화 등을 통해 메시지를 변환하거나 수신 승인과 같은 자체 프로토콜 제어 메시지를 주고 받습니다.
채널 셰이프
각 채널에서는 채널 셰이프 인터페이스 또는 채널 셰이프라고 하는 인터페이스를 하나 이상 구현합니다. 이러한 채널 셰이프에서는 채널에서 구현되어 채널 사용자가 호출하는 보내기 및 받기 또는 요청 및 응답과 같은 통신 기반 메서드를 제공합니다. 채널 셰이프의 맨 아래에는 IChannel 인터페이스가 있으며, 이 인터페이스는 스택 내 채널에 의해 노출되는 임의의 기능에 액세스하기 위한 계층화된 메커니즘으로 GetProperty<T> 메서드를 제공합니다. IChannel을 확장하는 다섯 개의 채널 셰이프는 다음과 같습니다.
또한 이러한 각 셰이프에는 세션 지원을 위해 System.ServiceModel.Channels.ISessionChannel을 확장하는 해당 항목이 있습니다. 이러한 항목은 다음과 같습니다.
채널 셰이프는 기존 전송 프로토콜에서 지원하는 몇 가지 기본 메시지 교환 패턴에 따라 패턴화됩니다. 예를 들어 단방향 메시징은 IInputChannel/IOutputChannel 쌍에 해당하고, 요청-회신은 IRequestChannel/IReplyChannel 쌍에 해당하며, 양방향 이중 통신은 IDuplexChannel(IInputChannel 및 IOutputChannel을 모두 확장)에 해당합니다.
채널 스택을 사용한 프로그래밍
채널 스택은 일반적으로 바인딩을 통해 채널 스택이 만들어지는 팩터리 패턴을 사용하여 만들어집니다. 보내는 쪽에서 바인딩을 사용하여 ChannelFactory를 빌드하는데, 이를 통해 채널 스택을 차례로 빌드하고 스택의 맨 위 채널에 참조를 반환합니다. 그러면 응용 프로그램에서 이 채널을 사용하여 메시지를 보낼 수 있습니다. 자세한 내용은 클라이언트 채널 수준 프로그래밍을 참조하십시오.
받는 쪽에서는 바인딩을 사용하여 IChannelListener를 빌드하는데, 이를 통해 들어오는 메시지를 수신 대기합니다. IChannelListener에서는 채널 스택을 만들고 맨 위 채널에 응용 프로그램 참조를 전달하여 메시지를 수신 대기 응용 프로그램에 제공합니다. 그러면 응용 프로그램에서 이 채널을 사용하여, 들어오는 메시지를 받습니다. 자세한 내용은 서비스 채널 수준 프로그래밍을 참조하십시오.
채널 개체 모델
채널 개체 모델은 채널, 채널 수신기 및 채널 팩터리를 구현하는 데 필요한 핵심 인터페이스 집합입니다. 또한 사용자 지정 구현을 도와 주는 몇 가지 기본 클래스도 있습니다.
채널 수신기는 들어오는 메시지를 수신 대기한 다음, 이를 채널 수신기에서 만든 채널을 통해 위 계층으로 전달합니다.
채널 팩터리는 메시지를 전송하고 만들어진 모든 채널을 채널 팩터리 종료 시 닫는 데 사용하는 채널을 만듭니다.
ICommunicationObject는 모든 통신 개체에서 구현하는 기본 상태 시스템을 정의하는 핵심 인터페이스입니다. CommunicationObject는 다른 채널 클래스에서 인터페이스를 다시 구현하지 않고 파생할 수 있는 이러한 핵심 인터페이스 구현을 제공합니다. 하지만 반드시 이렇게 할 필요는 없으며, 사용자 지정 채널을 통해 ICommunicationObject를 CommunicationObject에서 상속하지 않고 바로 구현할 수도 있습니다. 그림 3의 클래스는 모두 채널 모델의 일부로 간주되지 않으며, 채널을 빌드하려는 사용자 지정 채널 구현자가 사용할 수 있는 도우미입니다.
다음 항목에서는 채널 개체 모델 및 사용자 지정 채널을 편리하게 빌드할 수 있는 다양한 개발 영역에 대해 설명합니다.
항목 | 설명 |
---|---|
서비스 응용 프로그램에서 들어오는 채널을 수신 대기하는 채널 수신기에 대해 설명합니다. |
|
서비스 응용 프로그램에 연결할 채널을 만드는 채널 팩터리에 대해 설명합니다. |
|
System.ServiceModel.ICommunicationObject 인터페이스 모델 상태가 채널에서 어떻게 바뀌는지에 대해 설명합니다. |
|
채널에서 지원할 수 있는 여섯 가지의 기본 메시지 교환 패턴에 대해 설명합니다. |
|
사용자 지정 채널에서 오류 및 예외를 처리하는 방법에 대해 설명합니다. |
|
응용 프로그램 모델에서 사용자 지정 채널을 사용할 수 있도록 지원하는 방법과 바인딩 및 바인딩 요소를 사용하여 메타데이터를 가져오거나 내보내는 방법에 대해 설명합니다. |