이 페이지에서는 Cloud Composer 및 트리거를 사용한 파이프라인 조정에 대해 설명합니다. Cloud Data Fusion은 Cloud Composer를 사용하여 파이프라인을 조정하는 것을 권장합니다. 조정을 더 간단하게 관리하는 방법이 필요한 경우 트리거를 사용하세요.
Composer
Cloud Composer로 파이프라인 조정
Cloud Composer를 사용하여 Cloud Data Fusion에서 파이프라인 실행을 조정하면 다음과 같은 이점이 있습니다.
- 중앙 집중식 워크플로 관리: 여러 Cloud Data Fusion 파이프라인의 실행을 일관되게 관리합니다.
- 종속 항목 관리: 올바른 실행 순서를 보장하려면 파이프라인 간의 종속 항목을 정의합니다.
- 모니터링 및 알림: Cloud Composer는 모니터링 기능과 오류에 대한 알림을 제공합니다.
- 다른 서비스와 통합: Cloud Composer를 사용하면 Cloud Data Fusion 및 기타 Google Cloud 서비스 전반에 걸친 워크플로를 조정할 수 있습니다.
Cloud Composer를 사용하여 Cloud Data Fusion 파이프라인을 조정하려면 다음 프로세스를 따르세요.
Cloud Composer 환경을 설정합니다.
- Cloud Composer 환경을 만듭니다. 환경이 없는 경우 Google Cloud 프로젝트에서 환경을 프로비저닝합니다. 이 환경이 조정 작업공간입니다.
- 권한 부여. Cloud Composer 서비스 계정에 Cloud Data Fusion에 액세스하는 데 필요한 권한(예: 파이프라인 시작, 중지, 나열 권한)이 있는지 확인합니다.
조정을 위한 방향성 비순환 그래프(DAG)를 정의합니다.
- DAG 만들기: Cloud Composer에서 Cloud Data Fusion 파이프라인의 조정 워크플로를 정의하는 DAG를 만듭니다.
- Cloud Data Fusion 연산자: DAG 내에서 Cloud Composer의 Cloud Data Fusion 연산자를 사용합니다. 이러한 연산자를 사용하면 Cloud Data Fusion과 프로그래매틱 방식으로 상호작용할 수 있습니다.
Cloud Data Fusion 연산자
Cloud Data Fusion 파이프라인 오케스트레이션에는 다음과 같은 연산자가 있습니다.
CloudDataFusionStartPipelineOperator
Cloud Data Fusion 파이프라인의 ID를 기준으로 실행을 트리거합니다. 여기에는 다음과 같은 파라미터가 있습니다.
- 파이프라인 ID
- 위치(Google Cloud 리전)
- 파이프라인 네임스페이스
- 런타임 인수(선택사항)
- 완료될 때까지 대기(선택사항)
- 제한 시간(선택사항)
CloudDataFusionStopPipelineOperator
실행 중인 Cloud Data Fusion 파이프라인을 중지할 수 있습니다.
CloudDataFusionDeletePipelineOperator
Cloud Data Fusion 파이프라인을 삭제합니다.
DAG 워크플로 빌드
DAG 워크플로를 빌드할 때는 다음 사항을 고려하세요.
- 종속 항목 정의: DAG 구조를 사용하여 작업 간의 종속 항목을 정의합니다. 예를 들어 한 네임스페이스의 파이프라인이 성공적으로 완료될 때까지 기다린 후 다른 네임스페이스의 다른 파이프라인을 트리거하는 작업이 있을 수 있습니다.
- 예약: 매일 또는 매시간과 같은 특정 간격으로 실행되도록 DAG를 예약하거나 수동으로 트리거되도록 설정합니다.
자세한 내용은 Cloud Composer 개요를 참조하세요.
트리거
트리거를 사용하여 파이프라인 조정
Cloud Data Fusion 트리거를 사용하면 하나 이상의 업스트림 파이프라인이 완료될 때(성공, 실패 또는 지정된 조건) 다운스트림 파이프라인을 자동으로 실행할 수 있습니다.
트리거는 다음과 같은 작업에 유용합니다.
- 데이터를 한 번 정리한 다음 여러 다운스트림 파이프라인에서 사용할 수 있도록 합니다.
- 파이프라인 간에 런타임 인수 및 플러그인 구성과 같은 정보를 공유합니다. 이 작업을 페이로드 구성이라고 합니다.
- 실행할 때마다 업데이트해야 하는 정적 파이프라인 대신 시간/일/주/월별 데이터를 사용하여 실행되는 동적 파이프라인 집합이 있습니다.
예를 들어 회사의 배송에 관한 모든 정보가 포함된 데이터 세트가 있습니다. 이 데이터를 기반으로 몇 가지 비즈니스 질문에 답변하려고 합니다. 이를 위해 배송에 관한 원시 데이터를 정리하는 배송 데이터 정리라는 파이프라인을 만듭니다. 그런 다음 정리된 데이터를 읽고 지정된 기준점을 초과하여 지연된 미국 내 배송을 찾는 두 번째 파이프라인인 미국 배송 지연을 만듭니다. 업스트림 배송 데이터 정리 파이프라인이 완료되는 즉시 미국 배송 지연 파이프라인을 트리거할 수 있습니다.
또한 다운스트림 파이프라인은 업스트림 파이프라인의 출력을 소비하므로 다운스트림 파이프라인이 이 트리거를 사용하여 실행될 때 읽을 입력 디렉터리(업스트림 파이프라인이 출력을 생성한 디렉터리)도 수신하도록 지정해야 합니다. 이 프로세스를 페이로드 구성 전달이라고 하며 런타임 인수로 정의합니다. 이를 통해 시간/일/주/월별 데이터를 사용하여 실행되는 동적 파이프라인 집합을 보유할 수 있습니다(실행할 때마다 업데이트해야 하는 정적 파이프라인이 아님).
트리거로 파이프라인을 조정하려면 다음 프로세스를 따르세요.
업스트림 및 다운스트림 파이프라인 만들기
- Cloud Data Fusion Studio에서 조정 체인을 구성하는 파이프라인을 설계하고 배포합니다.
- 워크플로에서 어떤 파이프라인이 완료되면 다음 파이프라인(다운스트림)이 활성화되는지 고려하세요.
선택사항: 업스트림 파이프라인에 대한 런타임 인수를 전달합니다.
- 파이프라인 간에 페이로드 구성을 런타임 인수로 전달해야 하는 경우 런타임 인수를 구성합니다. 이러한 인수는 실행 중에 다운스트림 파이프라인에 전달될 수 있습니다.
다운스트림 파이프라인에 인바운드 트리거 만들기
- Cloud Data Fusion Studio에서 목록 페이지로 이동합니다. 배포 탭에서 다운스트림 파이프라인의 이름을 클릭합니다. 파이프라인의 배포 보기가 표시됩니다.
- 페이지 가운데 왼쪽에서 인바운드 트리거를 클릭합니다. 사용 가능한 파이프라인 목록이 표시됩니다.
- 업스트림 파이프라인을 클릭합니다. 다운스트림 파이프라인이 실행되는 시간에 대한 조건으로 하나 이상의 업스트림 파이프라인 완료 상태(성공, 실패, 중지)를 선택합니다.
- 업스트림 파이프라인이 페이로드 구성이라고 부르는 정보를 다운스트림 파이프라인과 공유하도록 설정하려면 트리거 구성을 클릭한 후 페이로드 구성을 런타임 인수로 전달 단계를 수행합니다. 그렇지 않으면 트리거 사용 설정을 클릭합니다.
트리거 테스트
- 업스트림 파이프라인 실행을 시작합니다.
- 트리거가 올바르게 구성되면 구성된 조건에 따라 업스트림 파이프라인이 완료될 때 다운스트림 파이프라인이 자동으로 실행됩니다.
페이로드 구성을 런타임 인수로 전달
페이로드 구성은 업스트림 파이프라인에서 다운스트림 파이프라인으로 정보를 공유할 수 있게 해줍니다. 예를 들어 이 정보는 출력 디렉터리, 데이터 형식, 파이프라인이 실행된 날짜일 수 있습니다. 그런 다음 이 정보는 올바르게 읽어야 할 데이터 세트 확인과 같은 결정을 내리기 위해 다운스트림 파이프라인에 사용됩니다.
업스트림 파이프라인에서 다운스트림 파이프라인으로 정보를 전달하려면다운스트림 파이프라인의 런타임 인수를 런타임 인수의 값 또는 업스트림 파이프라인의 모든 플러그인 구성의 값으로 설정합니다.
다운스트림 파이프라인이 트리거되어 실행될 때마다 다운스트림 파이프라인을 트리거한 업스트림 파이프라인의 특정 실행에 대한 런타임 인수를 사용하여 페이로드 구성을 설정합니다.
페이로드 구성을 런타임 인수로 전달하려면 다음 단계를 따르세요.
- 인바운드 트리거 만들기에서 중단한 지점을 선택하고, 트리거 구성을 클릭하면 업스트림 파이프라인에 대해 이전에 설정한 런타임 인수가 표시됩니다. 이 트리거가 실행될 때 업스트림 파이프라인에서 다운스트림 파이프라인으로 전달하려는 런타임 인수를 선택합니다.
- 플러그인 구성 탭을 클릭하여 트리거될 때 업스트림 파이프라인에서 다운스트림 파이프라인으로 전달되는 항목 목록을 확인합니다.
- 트리거 구성 및 사용 설정을 클릭합니다.