다음을 통해 공유


메시지 큐 태스크

메시지 큐 태스크에서는 MSMQ(메시지 큐)를 사용하여 SQL Server Integration Services 패키지 간에 메시지를 보내고 받거나 사용자 지정 응용 프로그램에서 처리되는 응용 프로그램 큐에 메시지를 보낼 수 있습니다. 이러한 메시지는 단순한 텍스트, 파일 또는 변수와 해당 값의 형태로 사용될 수 있습니다.

메시지 큐 태스크를 사용하면 회사 전반의 작업을 조정할 수 있습니다. 대상이 없거나 사용 중인 경우에는 메시지를 큐에 저장하고 다음에 배달할 수 있습니다. 예를 들어 네트워크에 연결될 때 메시지를 받는 판매 영업 직원의 랩톱 컴퓨터가 오프라인인 경우 이 태스크는 메시지를 큐에 저장할 수 있습니다. 메시지 큐 태스크는 다음 용도로 사용할 수 있습니다.

  • 다른 패키지가 체크 인될 때까지 태스크 실행이 지연됩니다. 예를 들어 메시지 큐 태스크는 각 소매점 사이트에서 일일 관리가 끝난 후 회사 컴퓨터에 메시지를 보냅니다. 회사 컴퓨터에서 실행되는 패키지에는 특정 소매점 사이트의 메시지를 대기 중인 메시지 큐 태스크가 있습니다. 소매점 사이트의 메시지가 도착하면 태스크가 해당 사이트의 데이터를 업로드합니다. 모든 사이트가 체크 인된 다음에는 패키지가 요약 합계를 계산합니다.

  • 데이터 파일을 처리 컴퓨터로 보냅니다. 예를 들어 한 식당에 있는 현금 등록기의 출력을 회사 급여 시스템에 데이터 파일 메시지로 보내서 각 웨이터의 팁에 대한 데이터를 추출할 수 있습니다.

  • 회사 전체에 파일을 배포합니다. 예를 들어 패키지는 메시지 큐 태스크를 사용하여 패키지 파일을 다른 컴퓨터에 보낼 수 있습니다. 대상 컴퓨터에서 실행 중인 패키지는 메시지 큐 태스크를 사용하여 패키지를 로컬로 검색하고 저장합니다.

메시지를 보내거나 받을 때 메시지 큐 태스크는 데이터 파일, 문자열, 변수에 대한 문자열 메시지 또는 변수 중 하나의 메시지 유형을 사용합니다. 변수에 대한 문자열 메시지의 메시지 유형은 메시지를 받을 때만 사용할 수 있습니다.

이 태스크는 MSMQ 연결 관리자를 사용하여 메시지 큐에 연결합니다. 자세한 내용은 MSMQ 연결 관리자를 참조하십시오. 메시지 큐에 대한 자세한 내용은 MSDN Library를 참조하십시오.

메시지 큐 태스크를 사용하려면 Integration Services 서비스가 설치되어 있어야 합니다. SQL Server 설치 마법사의 설치할 구성 요소 페이지 또는 기능 선택 페이지에서 선택하여 설치할 수 있는 일부 SQL Server 구성 요소는 Integration Services 구성 요소의 일부 하위 집합을 설치합니다. 이러한 구성 요소는 특정 태스크에 유용하지만 Integration Services의 기능이 제한됩니다. 예를 들어 SQL Server Data Tools(SSDT) 옵션을 선택하면 패키지 디자인에 필요한 Integration Services 구성 요소가 설치되지만 Integration Services 서비스가 설치되지 않기 때문에 메시지 큐 태스크가 작동하지 않습니다. Integration Services를 전체 설치하려면 설치할 구성 요소 페이지에서 Integration Services를 선택해야 합니다. 메시지 큐 태스크 설치 및 실행 방법은 Integration Services 설치를 참조하십시오.

[!참고]

컴퓨터의 운영 체제가 FIPS 모드에서 구성되고 태스크에서 암호화를 사용하는 경우 메시지 큐 태스크는 FIPS(Federal Information Processing Standard) 140-2와 호환되지 않습니다. 메시지 큐 태스크에서 암호화를 사용하지 않는 경우에는 태스크가 성공적으로 실행됩니다.

메시지 유형

메시지 큐 태스크에서 제공하는 메시지 유형을 다음과 같은 방법으로 구성할 수 있습니다.

  • Data file 메시지는 파일에 메시지가 포함되도록 지정합니다. 메시지를 받을 때 파일을 저장하고, 기존 파일을 덮어쓰고, 메시지를 받을 수 있는 태스크의 패키지를 지정하도록 태스크를 구성할 수 있습니다.

  • String 메시지는 메시지를 문자열로 지정합니다. 메시지를 받을 때 받은 문자열을 사용자 정의 문자열과 비교하고 비교 결과에 따라 동작을 취하도록 태스크를 구성할 수 있습니다. 문자열 비교 시에는 전체 문자열 일치 및 대/소문자 구분 여부를 지정하거나 하위 문자열을 사용할 수 있습니다.

  • String message to variable은 원본 메시지를 대상 변수에 전송되는 문자열로 지정합니다. 전체 문자열 일치, 대/소문자 구분 또는 하위 문자열 비교를 사용하여 받은 문자열을 사용자 정의 문자열과 비교하도록 태스크를 구성할 수 있습니다. 이 메시지 유형은 태스크에서 메시지를 받는 경우에만 사용할 수 있습니다.

  • Variable은 메시지에 하나 이상의 변수가 포함되도록 지정합니다. 메시지에 포함된 변수 이름을 지정하도록 메시지를 구성할 수 있습니다. 메시지를 받을 때 메시지를 받아올 패키지와 메시지의 대상인 변수를 모두 지정하도록 태스크를 구성할 수 있습니다.

메시지 보내기

메시지 큐 태스크에서 메시지를 보내도록 구성할 경우 메시지 큐 기술이 현재 지원하는 RC2 및 RC4 암호화 알고리즘 중 하나를 사용하여 메시지를 암호화할 수 있습니다. 이 두 암호화 알고리즘은 현재 메시지 큐 기술에서 지원하지 않는 최신 알고리즘에 비해 암호화 방식이 취약한 것으로 간주됩니다. 따라서 메시지 큐 태스크를 사용하여 메시지를 전송할 때는 암호화 요구를 신중하게 고려해야 합니다.

메시지 받기

메시지를 받을 때는 다음과 같은 방법으로 메시지 큐 태스크를 구성할 수 있습니다.

  • 메시지를 무시하거나 큐에서 메시지를 제거합니다.

  • 제한 시간을 지정합니다.

  • 제한 시간이 되면 오류가 발생합니다.

  • 메시지가 Data file에 저장된 경우 기존 파일을 덮어씁니다.

  • 메시지에서 Data file message 유형이 사용되는 경우 메시지 파일을 다른 파일 이름으로 저장합니다.

메시지 큐 태스크에 사용할 수 있는 사용자 지정 로깅 메시지

다음 표에서는 메시지 큐 태스크에 대한 사용자 지정 로그 항목을 나열합니다. 자세한 내용은 Integration Services(SSIS) 로깅로깅할 메시지 사용자 지정를 참조하십시오.

로그 항목

설명

MSMQAfterOpen

태스크에서 메시지 큐 열기를 완료했음을 나타냅니다.

MSMQBeforeOpen

태스크에서 메시지 큐 열기를 시작했음을 나타냅니다.

MSMQBeginReceive

태스크에서 메시지 받기를 시작했음을 나타냅니다.

MSMQBeginSend

태스크에서 메시지 보내기를 시작했음을 나타냅니다.

MSMQEndReceive

태스크에서 메시지 받기를 완료했음을 나타냅니다.

MSMQEndSend

태스크에서 메시지 보내기를 완료했음을 나타냅니다.

MSMQTaskInfo

태스크에 대한 설명 정보를 제공합니다.

MSMQTaskTimeOut

태스크 시간이 초과되었음을 나타냅니다.

메시지 큐 태스크 구성

SSIS 디자이너를 사용하거나 프로그래밍 방식으로 속성을 설정할 수 있습니다. SSIS 디자이너에서 설정할 수 있는 속성에 대한 자세한 내용을 보려면 다음 항목 중 하나를 클릭하십시오.

프로그래밍 방식으로 이러한 속성을 설정하는 방법은 개발자 가이드에서 Microsoft.SqlServer.Dts.Tasks.MessageQueueTask.MessageQueueTask 클래스에 대한 설명서를 참조하십시오.

관련 태스크

SSIS 디자이너에서 이러한 속성을 설정하는 방법은 태스크 또는 컨테이너의 속성 설정을 참조하십시오.

관련 내용

Integration Services 아이콘(작은 아이콘) Integration Services 관련 최신 정보 얻기

Microsoft의 최신 다운로드, 문서, 샘플 및 비디오와 커뮤니티에서 선택된 솔루션을 보려면 MSDN의 Integration Services 페이지를 방문하십시오.


이러한 업데이트에 대한 자동 알림을 받으려면 해당 페이지에서 제공하는 RSS 피드를 구독하십시오.

참고 항목

개념

Integration Services 태스크

제어 흐름