일괄 처리된 EDI 교환 어셈블
개별 트랜잭션 집합 일괄 처리 요소를 EDI 교환으로 어셈블하려면 BizTalk Server EDI 및 AS2는 다음을 수행합니다.
일괄 처리할 일괄 처리 요소 식별
개별 일괄 처리 요소 수신 시 유효성 검사 및 버퍼링
특정 일괄 처리 요소 검색 및 릴리스 조건 충족 시 일괄 처리된 교환 어셈블
개별 메시지의 컬렉션을 일괄 처리로 전환하는 시작 시간은 일괄 처리 활성화 조건에 따라 결정됩니다. 일괄 처리가 릴리스되는 시간은 일괄 처리 릴리스 조건에 따라 결정됩니다. 이러한 두 조건 집합에 대한 자세한 내용은 나가는 일괄 처리 구성을 참조하세요.
나가는 일괄 처리된 메시지의 메시지 흐름
BizTalk Server 보내는 메시지를 일괄 처리하도록 구성된 경우 BizTalk Server 구성 요소는 다음 일련의 단계를 수행하여 일괄 처리된 메시지를 보내도록 준비합니다. 이 일련의 단계에서는 BatchMarker 파이프라인 구성 요소가 있는 EDIReceive 파이프라인에서 송신을 위해 일괄 처리되는 트랜잭션 집합이 있는 수신된 교환을 처리하는 경우에 대해 설명합니다.
EDIReceive 파이프라인의 BatchMarker 파이프라인 구성 요소는 파티 속성의 EDI 일괄 처리 필터 설정에서 일괄 처리해야 하는 메시지를 결정합니다. BatchMarker 파이프라인 구성 요소는 일괄 처리 필터 설정을 확인하고 그에 따라 동작하는 유일한 일괄 처리 구성 요소입니다.
하나의 일괄 처리 구성의 필터 설정만 메시지를 구독하는 경우 BatchMarker 구성 요소는 속성을
EDI.ToBeBatched = True
승격합니다. 그러면 일괄 처리 오케스트레이션에서 메시지를 선택합니다.둘 이상의 일괄 처리 구성의 필터 설정이 메시지 컨텍스트와 일치하는 경우 BatchMarker 구성 요소는 속성을 승격하고 일치하는
EDI.ToBeRouted = True
일괄 처리 ID를 포함하는 공백으로 구분된 목록으로 속성을 설정합니다EDI.BatchIds
. 그러면 라우팅 오케스트레이션에서 메시지에 등록합니다.참고
사용자 지정 수신 파이프라인 또는 사용자 지정 오케스트레이션에서 해당 컨텍스트 속성을 승격할 수 있습니다. 사용자 지정 수신 파이프라인에서는 BatchMarker 파이프라인 구성 요소를 사용하거나 BatchMarker 파이프라인 구성 요소를 사용하지 않고 속성을 승격할 수 있습니다.
라우팅 오케스트레이션은 및
EDI.BatchIds
가 승격되는EDI.ToBeRouted = True
트랜잭션 집합을 선택한 다음 트랜잭션 집합의 복사본을 만들어 에 포함된EDI.BatchIds
각 일괄 처리 ID에 대한 복사본이 있는지 확인합니다. 라우팅 오케스트레이션 집합 및EDI.BatchId
는 트랜잭션 집합EDI.ToBeBatched = True
의 각 복사본에 대해 일치하는 일괄 처리 구성의 일괄 처리 ID로 설정됩니다. 그러면 대한 일괄 처리 오케스트레이션에서 일괄 처리에 대한 트랜잭션 집합을 선택합니다.일괄 처리 오케스트레이션에서는 다음 속성이 승격된 모든 메시지를 선택합니다.
EDI.ToBeBatched = True
및 EDI.BatchId = 일괄 처리 오케스트레이션의 이 인스턴스와 연결된 일괄 처리의 일괄 처리 IDEDI.ToBeBatched = True
및 EDI.BatchName = 구성된 일괄 처리의 이름 및 EDI.DestinationPartyName = 일괄 처리 구성이 포함된 파티 이름BatchMarker 파이프라인 구성 요소가 있는 EDIReceive 파이프라인에서 들어오는 메시지를 처리하면 일괄 처리 오케스트레이션은 X12 또는 EDIFACT로 인코딩된 트랜잭션 집합만 일괄 처리합니다.
참고
각 활성 일괄 처리 구성에는 일괄 처리 오케스트레이션 인스턴스가 하나씩 있으며 각각 특정 일괄 처리 ID에 등록됩니다. 일괄 처리 ID 값은 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지의 ID 섹션에서 새 일괄 처리 구성을 만들 때 자동으로 설정됩니다.
일괄 처리 오케스트레이션에서는 일괄 처리할 각 트랜잭션 집합에 대해 유효성을 검사합니다. 트랜잭션 집합이 유효성 검사에 실패하면 컨텍스트 속성을 "True"로 설정합니다
EDI.BatchItemValidationFailure
. BatchSuspend 오케스트레이션은 해당 컨텍스트 속성을 기반으로 메시지를 선택하고 오류 정보를 게시한 다음 일시 중단됩니다.일괄 처리 릴리스 조건이 충족되면 일괄 처리 오케스트레이션에서 일괄 처리 요소를 일괄 처리에 어셈블하고 봉투(Envelope)를 만듭니다.
일괄 처리 오케스트레이션에서는 교환 일괄 처리를 완료한 후 해당 교환의 EDI.DestinationPartyName = %PartyName% 속성, EDI.BatchEncodingType = X12 또는 EDIFACT 속성 및 EDI.ToBeBatched = False 속성을 승격합니다.
송신 포트는 EDI에 따라 일괄 처리된 트랜잭션 집합을 선택합니다. DestinationPartyName = <PartyName>, EDI. BatchEncodingType = EDIFACT 또는 X12 및 EDI. ToBeBatched = False입니다.
일괄 처리 오케스트레이션 제어 메시지
일괄 처리 오케스트레이션은 다음 제어 메시지로 활성화, 종료 또는 재정의됩니다.
BatchActivation: 오케스트레이션이 이 메시지를 받으면 일괄 처리 오케스트레이션의 instance 만들어지고 오케스트레이션이 일괄 처리 요소를 수신하기 위해 활성화됩니다(일괄 처리 활성화 조건을 충족하는 경우). 이 제어 메시지는 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지에서 일괄 처리 구성의 시작 단추를 클릭하여 보냅니다.
BatchTermination: 오케스트레이션이 이 메시지를 받으면 기존 일괄 처리 요소에서 일괄 처리를 만들고, 메시지를 MessageBox에 게시하고, 종료합니다. 이 제어 메시지는 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지에서 일괄 처리 구성의 중지 단추를 클릭하여 보냅니다.
참고
규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지의 종료 섹션에 있는 종료 날짜 속성에 지정된 시간에 도달한 경우에도 오케스트레이션이 종료됩니다.
BatchOverride: 오케스트레이션이 이 메시지를 받으면 기존 요소에서 일괄 처리를 만들고 MessageBox에 메시지를 게시한 다음 다음 일괄 처리를 위해 메시지를 기다립니다. 이 제어 메시지는 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지에서 일괄 처리 구성의 재정의 단추를 클릭하여 보냅니다.
일괄 처리 오케스트레이션은 BatchControlMessageRecvLoc 수신 위치를 통해 제어 메시지를 받습니다. 이 SQL 수신 위치에 대한 폴링 간격은 기본적으로 30초로 설정되지만 수신 위치에 대한 SQL 전송 속성 대화 상자에서 변경할 수 있습니다. 폴링 간격을 줄이면 제어 메시지를 보낸 동작을 수행한 후 바로 BatchControlMessageRecvLoc 수신 위치에서 제어 메시지를 받게 됩니다(예: 일괄 처리 오케스트레이션을 시작한 경우).
일괄 처리 오케스트레이션을 시작하면 다음 단계가 수행됩니다.
시작 단추를 클릭하면 BizTalk Server 일괄 처리 오케스트레이션을 활성화할 파티 및 일괄 처리 ID를 나타내는 레코드를 테이블에 만듭니다.
BatchControlMessageRecvLoc 수신 위치에 연결된 SQL 어댑터가 폴링하여 데이터베이스에 레코드가 있는지 확인합니다.
레코드가 있으면 SQL 어댑터는 레코드의 정보를 사용하여 제어 메시지를 빌드합니다.
참고
이 방법으로 제어 메시지를 빌드하면 올바른 제어 메시지로 오케스트레이션을 시작할 수 있습니다.
BatchControlMessageRecvLoc 수신 위치는 제어 메시지를 수신하고 BizTalk Server 일괄 처리 오케스트레이션 instance 활성화합니다.
일괄 처리 구성 요소
BizTalk Server 다음 구성 요소를 사용하여 XML 트랜잭션 집합을 EDI 교환으로 일괄 처리합니다.
EDI 수신 파이프라인의 BatchMarkerReceivePipelineComponent
라우팅 오케스트레이션
일괄 처리 오케스트레이션
일괄 처리 오케스트레이션 업그레이드
BatchSuspend 오케스트레이션
EDI 송신 파이프라인
이러한 구성 요소는 BizTalk Server EDI 및 AS2를 설치하고 구성할 때 DLL로 설치됩니다.
참고
BizTalk Server EDI 및 AS2의 일괄 처리 구성 요소는 일괄 처리에서 트랜잭션 집합의 순서를 보장하지 않습니다.
BatchMarkerReceivePipelineComponent
EDI 수신 파이프라인의 BatchMarkerReceivePipelineComponent를 사용하면 일괄 처리 오케스트레이션에서 일괄 처리할 메시지를 선택할 수 있습니다. 이 파이프라인 구성 요소는 EDI 수신 파이프라인의 디스어셈블러 이후에 적용됩니다. 이 구성 요소는 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지의 필터 섹션에 있는 필터 조건 집합을 평가하고, 트랜잭션 집합을 라우팅 오케스트레이션 및 일괄 처리 오케스트레이션을 통해 처리하기 위해 다음 컨텍스트 속성으로 표시합니다.
단일 당사자가 일괄 처리할 메시지를 구독하는 경우 승격
ToBeBatched = True
되고 BatchId는 일치하는 일괄 처리 구성의 일괄 처리 ID 값으로 설정됩니다. 이렇게 하면 일괄 처리 오케스트레이션에서 선택할 수 있습니다.여러 일괄 처리가 일괄 처리할 메시지를 구독하는 경우 을
ToBeRouted = True
승격하고 속성 집합을 공백으로 구분된 일괄 처리 ID 목록으로 설정합니다EDI.BatchIds
. 이렇게 하면 라우팅 오케스트레이션에서 선택할 수 있습니다.등록이 없으면 컨텍스트 속성을 승격하지 않습니다. 즉, 트랜잭션 집합이 일괄 처리되지 않음을 나타냅니다.
파이프라인 구성 요소는 XML 이외의 메시지와 속성이 있는
ReuseEnvelope
메시지(유지된 일괄 처리)를 무시합니다. 확인이 일괄 처리되지 않으면 파이프라인 구성 요소는 ACK 메시지 유형(CONTRL, TA1 및 997)을 무시합니다. 라우팅 및 일괄 처리 오케스트레이션의 처리를 최적화하기 위해 BatchMarkerPipelineComponent는 메시지 컨텍스트 속성MessageDestination
이 디스어셈블러에 의해 "SuspendedQueue"로 설정된 경우 메시지를 MessageBox로 전달합니다.EDIReceive 파이프라인 대신 사용자 지정 파이프라인을 사용하면 사용자 지정 파이프라인에 BatchMarker 구성 요소를 사용할 수 있습니다. EDIReceive 파이프라인을 사용하지 않고 오케스트레이션에서 메시지를 게시하는 경우 구성 요소 중 하나에서 활성 일괄 처리의 ID로 승격
ToBeBatched = True
해야BatchID
합니다.
라우팅 오케스트레이션
라우팅 오케스트레이션은 컨텍스트 속성과 컨텍스트 속성 ToBeRouted = True
EDI.BatchIds
이 공백으로 구분된 일괄 처리 ID 목록으로 설정된 모든 메시지를 구독합니다. 여러 일괄 처리 필터에서 일괄 처리할 메시지에 등록한 경우 이와 같은 동작이 수행됩니다. 라우팅 오케스트레이션은 에 포함된 각 일괄 처리 ID에 대한 메시지 복사본을 만듭니다 EDI.BatchIds
. 그러면 각 복사본에 두 가지 새로운 컨텍스트 속성이 자동 삽입됩니다.
EDI.BatchID
- 이 메시지가 사용될 일괄 처리 ID로 설정됨EDI.ToBeBatched
- True로 설정됨그런 다음 이 복사본을 일괄 처리 오케스트레이션에서 선택할 MessageBox로 라우팅합니다. 각 대상 일괄 처리 ID는 특정 일괄 처리 ID에 대해 필터를 사용하여 동일한 오케스트레이션의 단일 인스턴스를 사용합니다.
일괄 처리 오케스트레이션
일괄 처리 오케스트레이션은 기간에 따라 일괄 처리 요소(트랜잭션 집합)를 버퍼링하고 이를 교환에 어셈블한 후 해당 교환을 릴리스 조건에 따라 송신 파이프라인으로 릴리스하는 상태 저장 서비스입니다.
활성화된 후 일괄 처리 오케스트레이션의 instance 특정 인코딩 형식의 메시지를 지정된 파티에 일괄 처리할 수 있습니다(시작 날짜/시간이 경과한 경우). 언제든 어느 한 번에는 활성 일괄 처리 구성당 하나씩 여러 일괄 처리 오케스트레이션 인스턴스가 있을 수 있습니다. 일괄 처리 오케스트레이션의 단일 instance 단일 일괄 처리 구성에 대해 여러 일괄 처리를 해제할 수 있습니다. 종료 조건이 충족되면 일괄 처리 오케스트레이션 인스턴스가 종료됩니다. 일괄 처리 오케스트레이션의 새 instance 시작 단추를 사용하여 TPM(거래 업체 관리)에서 수동으로 만들어야 합니다.
규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지의 활성화 섹션에 표시된 날짜 시간이 시작되기 전에 일괄 처리 오케스트레이션이 시작되면 활성화 범위에 지정된 메시지만 받습니다. 날짜 시간이 시작되기 전에 보낸 메시지는 받지 않습니다.
일괄 처리 오케스트레이션은 다음을 수행합니다.
컨텍스트 속성
EDI.ToBeBatched = True
과EDI.BatchId
일괄 처리 구성의 ID 또는EDI.ToBeBatched = True
EDI를 사용하여 XML 일괄 처리 요소를 구독합니다. BatchName = 구성된 일괄 처리 및 EDI의 이름입니다. DestinationPartyName = 일괄 처리 구성을 포함하는 파티 이름입니다. 루프에서 수신 작업 작업을 사용하여 일괄 처리 요소를 받 습니다.참고
일괄 처리 오케스트레이션은 규약 속성 대화 상자의 단방향 규약 탭에 있는 일괄 처리 구성 페이지의 필터 섹션에 있는 필터 조건 집합을 기반으로 트랜잭션 집합을 일괄 처리하지 않습니다. 위에 나와 있는 컨텍스트 속성이 설정된 트랜잭션 집합에 등록합니다. BatchMarker 파이프라인 구성 요소는 파티 속성의 필터 설정을 기반으로 해당 컨텍스트 속성을 설정하고 승격합니다.
컨텍스트 속성에서
BatchId
식별된 파티의 일괄 처리 구성 설정을 검색합니다.파티 설정을 기반으로 일괄 처리 요소(트랜잭션 집합)의 유효성을 검사합니다.
일괄 처리 요소에 오류가 있는 경우 일괄 처리 오케스트레이션은 해당 트랜잭션 집합
EDI.BatchItemValidationFailure = True
에서 다음 속성을 승격합니다. BatchElementSuspend 오케스트레이션은 이 속성이 승격된 트랜잭션 집합을 구독합니다. 이 오케스트레이션은 교환을 일괄 처리하는 중에 발생한 첫 번째 오류에 대한 자세한 오류 정보를 제공합니다.일괄 처리 요소에 오류가 없는 경우 해당 일괄 처리 요소에 대한 참조를 보관합니다.
적절한 제어 메시지를 받거나 일괄 처리 릴리스 조건이 충족되면 수신 작업 루프에서 벗어나 MessageBox에서 모든 일괄 처리 요소를 검색하고 교환을 어셈블합니다.
교환에 대한 컨텍스트 속성을
ToBeBatched = False
설정하고 Context 속성 DestinationPartyName = %PartyName% 여기서 %PartyName%은 메시지가 의도된 파티의 이름입니다.참고
송신 포트가 속성
EDI.ToBeBatched = False
및 EDI 중 하나 또는 모두를 구독하는 경우 DestinationPartyName = %PartyName%, 해당 송신 포트는 일괄 처리된 교환을 선택할 수 있습니다. 송신 포트가 선택하도록 의도한 이 일괄 처리된 교환만 선택하도록 송신 포트의 필터를 구성했는지 확인합니다.참고
일괄 처리 오케스트레이션에 의해 MessageBox로 삭제된 교환에는 속성
EDI.ToBeBatched = False
, EDI만 있습니다. DestinationPartyName = %PartyName%, and EDI. BatchEncodingType = 컨텍스트로 승격된 "X12" 또는 "EDIFACT" 원래 트랜잭션 집합의 모든 컨텍스트 속성이 손실됩니다.X12로 인코딩된 교환의 경우 봉투(Envelope)에 다음 속성이 적용됩니다.
ISA6: 교환 보낸 사람 ID
ISA8: 교환 받는 사람 ID
ISA15: 사용 표시기
ISA_Blob(컨텍스트에 기록)
EDIFACT로 인코딩된 교환의 경우 봉투(Envelope)에 다음 속성이 적용됩니다.
UNB2.1: 교환 보낸 사람 ID
UNB3.1: 교환 받는 사람 ID
UNB2.3: 역라우팅 주소
UNB11: 사용 표시기
UNA_Blob(컨텍스트에 기록)
UNB_Blob(컨텍스트에 기록)
MessageBox에 EDI 송신 파이프라인에서 선택할 일괄 처리된 교환을 배달합니다.
UpgradeBatching 오케스트레이션
UpgradeBatching 오케스트레이션은 EDI.ToBeBatched
속성이 true로 설정되어 있지만 속성이 설정되지 않은 EDI.BatchID
메시지를 처리합니다.
이전 버전의 BizTalk Server 각 당사자는 하나의 일괄 처리 구성만 가질 수 있었습니다. true EDI.DestinationPartyId
로 설정된 메시지를 EDI.ToBeBatched
처리할 때 는 당사자를 확인하는 데 사용된 다음, 일괄 처리 구성을 규약 속성에서 읽었습니다.
BizTalk Server 각 당사자는 여러 일괄 처리 구성을 연결할 수 있으므로 EDI.DestinationPartyId
에서는 사용할 일괄 처리 구성을 결정하기에 충분한 정보를 제공하지 않습니다. BizTalk Server 메시지를 받으면 속성을 사용하여 메시지를 EDI.BatchId
처리할 때 사용해야 하는 특정 일괄 처리 구성을 식별합니다.
BizTalk Server 업그레이드한 후에도 속성을 사용하여 파티 구성을 EDI.DestinationPartyId
지정하는 사용자 지정 파이프라인이 있을 수 있습니다. true EDI.DestinationPartyID
로 설정된 메시지가 수신되고 EDI.ToBeBatched
EDI 대신 가 설정된 경우 BatchID, UpgradeBatching 오케스트레이션은 어떤 일괄 처리 구성을 사용해야 하는지 결정하려고 시도합니다.
UpgradeBatching 오케스트레이션에서는 다음 등록 필터를 사용하여 일괄 처리용으로 표시된 문서에 등록하나 일괄 처리 ID는 지정하지 않습니다.
EDI.ToBeBatched=True
EDI.EncodingType
존재EDI.DestinationPartyId
존재오케스트레이션에서 메시지를 받으면 파티 이름 및 인코딩 유형을 사용하여 메시지에 대해 일치하는 일괄 처리 구성을 찾으려고 합니다. 속성은
EDI.DestinationPartyID
파티 이름을 확인하는 데 사용되며, 오케스트레이션은 PartyName>+EncodingType>+<Default와 일치하는 <일괄 처리 이름을 찾습니다. 예를 들어 파티 이름이 Contoso이고 값EDI.EncodingType
이 X12인 경우 오케스트레이션은 ContosoX12Default라는 일괄 처리를 찾습니다.일치하는 일괄 처리 구성을 찾으면 메시지를 다음 속성과 함께 메시지 상자로 되돌립니다.
EDI.ToBeBatched = True
EDI.ToBeRouted = False
EDI.BatchId = 일치하는 일괄 처리의 일괄 처리 ID
그런 다음 일괄 처리 오케스트레이션에서 메시지를 처리합니다.
참고
일치하는 일괄 처리를 찾지 못하면 다음과 같은 결과가 나타납니다.
- 메시지를 BatchSuspend 오케스트레이션으로 보낼 수 없습니다.
- UpgradeBatching 오케스트레이션 인스턴스 및 메시지가 일시 중단됩니다.
- 일괄 처리를 찾을 수 없다는 내용의 오류가 이벤트 로그에 기록됩니다.
BatchSuspend 오케스트레이션
BatchSuspend 오케스트레이션이 일괄 처리 오케스트레이션에서 받은 잘못된 메시지를 처리합니다. 오케스트레이션 인스턴스 실행을 중지하지 않고 오케스트레이션(이 경우, 일괄 처리 오케스트레이션)에서 메시지를 일시 중단할 직접적인 방법은 없기 때문에 BatchSuspend 오케스트레이션이 필요합니다.
일괄 처리 오케스트레이션 인스턴스에서 메시지를 받으면 받은 메시지에 대한 유효성 검사를 시도합니다. 메시지 유효성 검사에 실패하면 일괄 처리 오케스트레이션은 BatchSuspend 오케스트레이션의 instance 만들고 컨텍스트 속성을 True로 설정합니다EDI.BatchItemValidationFailure
. BatchSuspend 오케스트레이션이 해당 컨텍스트 속성이 True로 설정된 모든 메시지에 등록합니다. 잘못된 트랜잭션 집합을 BatchSuspend 오케스트레이션으로 라우팅한 후에는 BatchSuspend 오케스트레이션 인스턴스가 일시 중단됩니다.
BatchSuspend 오케스트레이션에서 발생한 첫 번째 오류에 대한 자세한 오류 정보를 제공합니다.
필터에서 속성을 사용하여 일괄 처리 오케스트레이션으로 유효성 검사에 실패하는 트랜잭션 집합을 처리하는 사용자 지정 오케스트레이션을 EDI.BatchElementValidationFailure
만들 수 있습니다.
EDI 송신 파이프라인
일괄 처리 오케스트레이션에서 일괄 처리된 교환을 받은 후 EDI 송신 파이프라인에서는 다음을 수행합니다.
X12로 인코딩된 교환의 경우 송신 파이프라인은 봉투(Envelope)에 다음 속성을 적용합니다.
ISA2: 인증 정보
ISA4: 보안 정보
ISA9: 교환 날짜
ISA10: 교환 시간
ISA13: 교환 컨트롤 번호
GS4: 날짜
GS5: 시간
GS6: 그룹 컨트롤 번호
ST2: 트랜잭션 집합 컨트롤 번호
EDIFACT로 인코딩된 교환의 경우 송신 파이프라인은 봉투(Envelope)에 다음 속성을 적용합니다.
UNB4.1: 날짜
UNB4.2: 시간
UNB5: 교환 컨트롤 참조
UNB6.1: 받는 사람 참조 암호
UNG4.1: 날짜
UNG4.2: 시간
UNG5: 기능 그룹 참조
UNG8: 응용 프로그램 암호
관련된 어댑터를 통해 메시지를 배달합니다.