방법: 메시지 컨텍스트 속성을 사용하여 내용 기준 라우팅 구현
목표
이 섹션에서는 Microsoft BizTalk ESB Toolkit 여정 Designer 사용하여 메시지 컨텍스트 속성에 따라 메시지 받는 사람을 선택한 다음, 여정 브로커 메시징 서비스를 사용하여 해당 받는 사람에게 메시지를 라우팅하는 일정을 만드는 방법을 보여 줍니다.
이 항목에서는 다음 단계를 완료합니다.
일정 브로커와 정적 확인자를 사용하여 두 개의 라우팅 서비스를 사용하여 여정을 만듭니다.
여정 테스트 클라이언트 샘플 애플리케이션을 사용하여 여정을 테스트합니다.
참고
현재 구현에는 오케스트레이션 기반 broker 서비스가 제공되지 않습니다.
필수 구성 요소
이 방법 항목의 절차에서는 개발 활동에 대한 필수 구성 요소를 완료해야 합니다.
단계
ESB 여정 DSL 모델을 만들려면
Visual Studio에서 C:\HowTos\Patterns\Patterns.sln을 엽니다.
솔루션 탐색기 여정라이브러리를 마우스 오른쪽 단추로 클릭하고 추가를 가리킨 다음 새 여정을 클릭합니다.
새 항목 추가 대화 상자의 템플릿 창에서 여정Dsl을 클릭합니다.
이름 상자에 ChoiceRouter를 입력한 다음 추가를 클릭합니다.
여정의 속성을 구성하려면
Visual Studio에서 ChoiceRouter 여정의 디자인 화면을 클릭합니다. ChoiceRouter 속성 창 다음 속성을 구성합니다.
모델 내보내기 드롭다운 목록에서 XML 여정 내보내기를 클릭합니다.
Extender 설정 섹션에서 여정 XML 파일 속성 옆에 있는 줄임표 단추(...)를 클릭합니다.
내보내기 모드 속성 드롭다운 목록에서 Strict를 클릭합니다.
XML 파일 선택 대화 상자의 파일 이름 상자에 C:\HowTos\Itineraries\ChoiceRouter를 입력하고 저장을 클릭합니다.
참고
이 단계를 통해 여정을 XML로 로컬 파일 위치로 내보낼 수 있습니다. 여정 데이터베이스 대신 로컬 파일 위치로 여정을 내보내면 ESB 테스트 클라이언트 애플리케이션을 사용하여 여정을 테스트할 수 있습니다. 이 프로세스는 이 방법 항목의 뒷부분에서 완료합니다.
여정의 구조를 정의하려면
도구 상자에서 On-Ramp 모델 요소를 디자인 화면으로 끌어옵니다. OnRamp1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ReceiveNAOrder를 입력합니다.
Extender 드롭다운 목록에서 On-Ramp Extender를 클릭합니다.
BizTalk 애플리케이션 드롭다운 목록에서 Microsoft.Practices.ESB를 클릭합니다.
수신 포트 드롭다운 목록에서 OnRamp.Itinerary를 클릭합니다.
도구 상자에서 Itinerary Broker 서비스 모델 요소를 디자이너 화면으로 끌어온 다음 On-Ramp 모델 요소의 오른쪽에 놓습니다. ItineraryBrokerService1에서 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 RouteBrokerService를 입력합니다.
Extender 드롭다운 목록에서 Messaging Broker Extender를 클릭합니다.
컨테이너 드롭다운 목록에서 ReceiveNAOrder를 확장한 다음 수신 처리기를 클릭합니다.
서비스 이름 드롭다운 목록에서 Microsoft.Practices.ESB.Itinerary.Services.Broker.MessagingBroker를 클릭합니다.
필터 컬렉션을 마우스 오른쪽 단추로 클릭한 다음 새 필터 추가를 클릭합니다. Filter1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ASMXFilter를 입력합니다.
필터 구현 드롭다운 목록을 클릭한 다음 XPath 필터를 클릭합니다.
Expression 속성을 클릭한 다음 count(/ContextProperties/Property[@name='InboundTransportLocation'][contains(., 'ProcessItinerary.asmx')]) > 0을 입력합니다.
필터 컬렉션을 마우스 오른쪽 단추로 클릭한 다음 새 필터 추가를 클릭합니다. Filter1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 WCFFilter를 입력합니다.
필터 구현 드롭다운 목록을 클릭하고 XPath 필터를 클릭합니다.
Expression 속성을 클릭한 다음 count(/ContextProperties/Property[@name='InboundTransportLocation'][contains(., 'ESB)를 입력합니다. 여정서비스.WCF')]) > 0.
RouteBrokerService 모델 요소의 Resolver 컬렉션을 마우스 오른쪽 단추로 클릭한 다음 새 해결 프로그램 추가를 클릭합니다. Resolver1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ResolverBrokerRoute를 입력합니다.
해결 프로그램 구현 드롭다운 목록에서 MessageContext Resolver 확장을 클릭합니다.
도구 상자에서 커넥터를 클릭합니다. ReceiveNAOrder 모델 요소에서 RouteBrokerService 모델 요소로 연결을 끌어옵니다.
도구 상자에서 여정 서비스 모델 요소를 디자인 화면으로 끌어서 RouteBrokerService 모델 요소 아래에 놓습니다. ItineraryService1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 RouteToFileFromASMX를 입력합니다.
여정 서비스 확장기 드롭다운 목록에서 메시징 확장자를 클릭합니다.
참고
이 속성은 프로세스가 파이프라인(메시징)에서 수행되도록 정의합니다. 또는 프로세스가 오케스트레이션에서 수행되는 경우 여정 서비스 Extender 속성을 Orchestration Extender로 설정합니다.
컨테이너 드롭다운 목록에서 ReceiveNAOrder를 확장한 다음 수신 처리기를 클릭합니다.
서비스 이름 드롭다운 목록에서 Microsoft.Practices.ESB.Services.Routing을 클릭합니다.
RouteToFileFromASMX 모델 요소의 Resolver 컬렉션을 마우스 오른쪽 단추로 클릭한 다음 새 해결 프로그램 추가를 클릭합니다. Resolver1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ResolverFromAsmx를 입력합니다.
해결 프로그램 구현 드롭다운 목록에서 정적 해결 프로그램 확장을 클릭합니다.
전송 이름 드롭다운 목록에서 파일을 클릭합니다.
전송 위치 속성을 클릭한 다음 c:\howtos\out\asmx%MessageId%.xml입력합니다.
도구 상자에서 오프 램프 모델 요소를 디자인 화면으로 끌어온 다음 RouteToFileFromASMX 모델 요소의 오른쪽에 놓습니다. OffRamp1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 SendASMXOrder를 입력합니다.
Extender 드롭다운 목록에서 오프 램프 ESB Extender를 클릭합니다.
BizTalk 애플리케이션 드롭다운 목록에서 GlobalBank.ESB를 클릭합니다.
송신 포트 드롭다운 목록에서 DynamicResolutionOneWay를 클릭합니다.
도구 상자에서 여정 서비스 모델 요소를 디자인 화면으로 끌어서 RouteToFileFromASMX 모델 요소와 SendASMXOrder 모델 요소 사이에 배치합니다. ItineraryService1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 SendPortFilterASMX를 입력합니다.
여정 서비스 확장기 드롭다운 목록에서 램프 끄기 확장기를 클릭합니다.
오프 램프 드롭다운 목록에서 SendASMXOrder를 확장하고 처리기 보내기를 클릭합니다.
도구 상자에서 커넥터를 클릭합니다. RouteToFileFromASMX 모델 요소에서 SendPortFilterASMX 모델 요소로 연결을 끌어옵니다.
도구 상자에서 커넥터를 클릭합니다. SendPortFilterASMX 모델 요소에서 SendASMXOrder 모델 요소로 연결을 끌어옵니다.
도구 상자에서 여정 서비스 모델 요소를 디자인 화면으로 끌어서 RouteBrokerService 모델 요소의 오른쪽에 놓습니다. ItineraryService1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 RouteToFileFromWCF를 입력합니다.
여정 서비스 확장기 드롭다운 목록에서 메시징 확장자를 클릭합니다.
참고
이 속성은 프로세스가 파이프라인(메시징)에서 수행되도록 정의합니다. 또는 프로세스가 오케스트레이션에서 수행되는 경우 여정 서비스 Extender 속성을 Orchestration Extender로 설정합니다.
컨테이너 드롭다운 목록에서 ReceiveNAOrder를 확장한 다음 수신 처리기를 클릭합니다.
서비스 이름 드롭다운 목록에서 Microsoft.Practices.ESB.Services.Routing을 클릭합니다.
RouteToFileFromWCF 모델 요소의 Resolver 컬렉션을 마우스 오른쪽 단추로 클릭한 다음 새 해결 프로그램 추가를 클릭합니다. Resolver1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ResolverFromWCF를 입력합니다.
해결 프로그램 구현 드롭다운 목록에서 정적 해결 프로그램 확장을 클릭합니다.
전송 이름 드롭다운 목록에서 파일을 클릭합니다.
전송 위치 속성을 클릭한 다음 c:\howtos\out\wcf%MessageId%.xml입력합니다.
도구 상자에서 오프 램프 모델 요소를 디자인 화면으로 끌어온 다음 RouteToFileFromWCF 모델 요소의 오른쪽에 놓습니다. OffRamp1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 SendWCFOrder를 입력합니다.
Extender 드롭다운 목록에서 오프 램프 ESB Extender를 클릭합니다.
BizTalk 애플리케이션 드롭다운 목록에서 GlobalBank.ESB를 클릭합니다.
송신 포트 드롭다운 목록에서 DynamicResolutionOneWay를 클릭합니다.
도구 상자에서 여정 서비스 모델 요소를 디자인 화면으로 끌어서 RouteToFileFromWCF 모델 요소와 SendWCFOrder 모델 요소 사이에 배치합니다. ItineraryService1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 SendPortFilterWCF를 입력합니다.
여정 서비스 확장기 드롭다운 목록에서 램프 끄기 확장기를 클릭합니다.
램프 끄기 드롭다운 목록에서 SendWCFOrder를 확장하고 처리기 보내기를 클릭합니다.
도구 상자에서 커넥터를 클릭합니다. RouteToFileFromWCF 모델 요소에서 SendPortFilterWCF 모델 요소로 연결을 끌어옵니다.
도구 상자에서 커넥터를 클릭합니다. SendPortFilterWCF 모델 요소에서 SendWCFOrder 모델 요소로 연결을 끌어옵니다.
도구 상자에서 RouteBrokerService의 오른쪽 테두리로 여정 아웃포트 모델 요소를 끌어옵니다. ItineraryBrokerOutPort1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 WCF 포트를 입력합니다.
필터 드롭다운 목록에서 WCFFilter를 클릭합니다.
해결 프로그램 드롭다운 목록에서 ResolverBrokerRoute를 클릭합니다.
도구 상자에서 여정 아웃포트 모델 요소를 RouteBrokerService의 아래쪽 테두리로 끌어옵니다. ItineraryBrokerOutPort1 속성 창 다음 속성을 구성합니다.
Name 속성을 클릭한 다음 ASMX 포트를 입력합니다.
필터 드롭다운 목록에서 ASMXFilter를 클릭합니다.
해결 프로그램 드롭다운 목록에서 ResolverBrokerRoute를 클릭합니다.
도구 상자에서 커넥터를 클릭합니다. WCF 포트 모델 요소에서 RouteToFileFromWCF 모델 요소로 연결을 끌어옵니다.
도구 상자에서 커넥터를 클릭합니다. ASMX 포트 모델 요소에서 RouteToFileFromASMX 모델 요소로 연결을 끌어옵니다.
여정 테스트 클라이언트에서 사용할 모델을 내보내려면
참고
브로커를 통해 라우팅을 테스트하려면 XML에서 한 번, 데이터베이스에 한 번 등 여정을 두 번 내보내야 합니다.
Visual Studio에서 ChoiceRouter 여정의 디자인 화면을 마우스 오른쪽 단추로 클릭한 다음 모델 내보내기를 클릭합니다.
참고
여정의 XML 버전이 Visual Studio에서 열립니다.
Windows Explorer C:\HowTos\Itineraries로 이동한 다음, 여정 XML(ChoiceRouter.xml)이 만들어집니다.
Visual Studio에서 ChoiceRouter 여정의 디자인 화면을 마우스 오른쪽 단추로 클릭한 다음 모델 내보내기를 클릭합니다.
속성 창 모델 내보내기 드롭다운 목록에서 데이터베이스 여정 내보내기를 클릭합니다.
속성 창 여정 데이터베이스 속성을 연결 문자열 설정하여 여정 데이터베이스를 가리킵니다.
여정 상태 속성 드롭다운 목록에서 배포를 선택합니다.
Visual Studio에서 ChoiceRouter 여정의 디자인 화면을 마우스 오른쪽 단추로 클릭한 다음 모델 내보내기를 클릭합니다.
여정을 테스트하려면
개발 활동(C:\HowTos\ESB.Itinerary.Test.exe - 바로 가기)에 대한 필수 구성 요소 중에 만든 바로 가기를 사용하여 여정 테스트 클라이언트 샘플 애플리케이션을 엽니다.
여정 테스트 클라이언트에서 WCF 서비스 검사 사용 상자의 선택 취소를 선택한 다음 여정 로드를 클릭합니다.
일정 파일 열기 대화 상자에서 C:\HowTos\Itineraries로 이동합니다. ChoiceRouter.xml를 선택한 다음 열기를 클릭하여 여정을 로드합니다.
확인을 클릭하여 "적재된 여정" 메시지를 닫습니다.
여정 테스트 클라이언트에서 메시지 로드 상자 옆에 있는 줄임표 단추(...)를 클릭합니다.
로드할 XML 문서 선택 대화 상자에서 C:\Patterns\HowTos로 이동합니다. NAOrderDoc.xml 선택한 다음 열기 를 클릭하여 테스트 메시지를 로드합니다.
요청 제출 단추를 클릭합니다. 테스트가 완료되면 확인을 클릭하여 표시되는 확인 메시지를 닫습니다.
Windows Explorer C:\HowTos\Out으로 이동합니다. ASMX%MessageID%.xml 메시지가 이 디렉터리에 기록되었는지 확인합니다.
여정 테스트 클라이언트 WCF 서비스 검사 사용 상자를 클릭합니다. 여정 이름 상자에 ChoiceRouter를 입력한 다음 요청 제출 단추를 클릭합니다. 테스트가 완료되면 확인을 클릭하여 확인 메시지를 닫습니다.
Windows Explorer C:\HowTos\Out으로 이동합니다. WCF%MessageID%.xml 메시지가 이 디렉터리에 기록되었는지 확인합니다.
추가 리소스
자세한 내용은 다음 관련 항목을 참조하십시오.