Cloud Composer 1에서 Apache Airflow DAG 실행
Cloud Composer 3 | Cloud Composer 2 | Cloud Composer 1
이 빠른 시작 가이드에서는 Cloud Composer 환경을 만들고 Cloud Composer 1에서 Apache Airflow DAG를 실행하는 방법을 보여줍니다.
Airflow를 처음 사용하는 경우 Airflow 개념, 객체, 사용법에 대한 자세한 내용은 Apache Airflow 문서의 Airflow 개념 튜토리얼을 참조하세요.
대신 Google Cloud CLI를 사용하려면 Cloud Composer에서 Apache Airflow DAG 실행(Google Cloud CLI)을 참조하세요.
Terraform을 사용하여 환경을 만들려면 환경 만들기(Terraform)를 참조하세요.
시작하기 전에
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Composer API.
-
빠른 시작을 완료하는 데 필요한 권한을 얻으려면 관리자에게 프로젝트에 대한 다음 IAM 역할을 부여해 달라고 요청하세요.
-
Cloud Composer 환경의 만들기 및 관리를 확인하려면 다음 안내를 따르세요.
-
환경 및 스토리지 객체 관리자(
roles/composer.environmentAndStorageObjectAdmin
) -
서비스 계정 사용자(
roles/iam.serviceAccountUser
)
-
환경 및 스토리지 객체 관리자(
- 로그 보기:
로그 뷰어(
roles/logging.viewer
)
역할 부여에 대한 자세한 내용은 프로젝트, 폴더, 조직에 대한 액세스 관리를 참조하세요.
-
Cloud Composer 환경의 만들기 및 관리를 확인하려면 다음 안내를 따르세요.
환경의 서비스 계정 만들기
사용자는 환경을 만들 때 서비스 계정을 지정합니다. 이 서비스 계정을 환경의 서비스 계정이라고 합니다. 환경은 이 서비스 계정을 사용하여 대부분의 작업을 실행합니다.
환경의 서비스 계정은 사용자 계정이 아닙니다. 서비스 계정은 사용자가 아닌 애플리케이션 또는 가상 머신 (VM) 인스턴스에서 사용하는 특별한 유형의 계정입니다.
환경의 서비스 계정을 만들려면 다음 안내를 따르세요.
Identity and Access Management 문서에 설명된 대로 새 서비스 계정을 만듭니다.
Identity and Access Management 문서에 설명된 대로 역할을 부여합니다. 필요한 역할은 Composer 작업자 (
composer.worker
)입니다.
환경 만들기
Google Cloud 콘솔에서 환경 만들기 페이지로 이동합니다.
이름 필드에
example-environment
을 입력합니다.위치 드롭다운 목록에서 Cloud Composer 환경의 리전을 선택합니다. 이 가이드에서는
us-central1
리전을 사용합니다.다른 환경 구성 옵션에 제공된 기본값을 사용합니다.
만들기를 클릭하고 환경이 생성될 때까지 기다립니다.
완료되면 환경 이름 옆에 녹색 체크표시가 나타납니다.
DAG 파일 만들기
Airflow DAG는 예약 및 실행하려는 태스크가 구성된 모음입니다. DAG는 표준 Python 파일에서 정의됩니다.
이 가이드에서는 quickstart.py
파일에 정의된 Airflow DAG 예시를 사용합니다.
이 파일의 Python 코드는 다음을 수행합니다.
- DAG,
composer_sample_dag
를 만듭니다. 이 DAG는 매일 실행됩니다. - 태스크 하나,
print_dag_run_conf
를 실행합니다. 태스크는 bash 연산자를 사용하여 DAG 실행 구성을 출력합니다.
quickstart.py
파일의 사본을 로컬 머신에 저장합니다.
환경의 버킷에 DAG 파일 업로드
모든 Cloud Composer 환경에는 Cloud Storage 버킷이 연결되어 있습니다. Cloud Composer의 Airflow는 이 버킷의 /dags
폴더에 있는 DAG만 예약합니다.
DAG를 예약하려면 로컬 머신에서 환경의 /dags
폴더로 quickstart.py
를 업로드합니다.
Google Cloud 콘솔에서 환경 페이지로 이동합니다.
환경 목록에서 환경 이름
example-environment
를 클릭합니다. 환경 세부정보 페이지가 열립니다.DAG 폴더 열기를 클릭합니다. 버킷 세부정보 페이지가 열립니다.
파일 업로드를 클릭한 후
quickstart.py
의 복사본을 선택합니다.파일을 업로드하려면 열기를 클릭합니다.
DAG 보기
DAG 파일을 업로드하면 Airflow는 다음을 수행합니다.
- 업로드한 DAG 파일을 파싱합니다. DAG가 Airflow에서 사용 가능해지기까지 몇 분 정도 걸릴 수 있습니다.
- 사용 가능한 DAG 목록에 DAG를 추가합니다.
- DAG 파일에 제공한 일정에 따라 DAG를 실행합니다.
DAG UI에서 확인하여 DAG가 오류 없이 처리되고 Airflow에서 사용할 수 있는지 확인합니다. DAG UI는 Google Cloud 콘솔에서 DAG 정보를 볼 수 있는 Cloud Composer 인터페이스입니다. 또한 Cloud Composer는 기본 Airflow 웹 인터페이스인 Airflow UI에 대한 액세스를 제공합니다.
Airflow가 이전에 업로드한 DAG 파일을 처리하고 첫 번째 DAG 실행을 완료할 때까지 약 5분 정도 기다립니다(뒷부분에서 설명).
Google Cloud 콘솔에서 환경 페이지로 이동합니다.
환경 목록에서 환경 이름
example-environment
를 클릭합니다. 환경 세부정보 페이지가 열립니다.DAG 탭으로 이동합니다.
composer_quickstart
DAG가 DAG 목록에 있는지 확인합니다.
DAG 실행 세부정보 보기
DAG를 한 번 실행하는 것을 DAG 실행이라고 합니다. DAG 파일의 시작 날짜가 어제로 설정되어 있으므로 Airflow는 예시 DAG의 DAG 실행을 즉시 실행합니다. Airflow는 이러한 방식으로 지정된 DAG의 일정을 따라잡습니다.
예시 DAG에는 콘솔에서 echo
명령어를 실행하는 print_dag_run_conf
태스크 하나가 포함되어 있습니다. 이 명령어는 DAG(DAG 실행의 숫자 식별자)에 대한 메타 정보를 출력합니다.
DAG 탭에서
composer_quickstart
를 클릭합니다. DAG의 실행 탭이 열립니다.DAG 실행 목록에서 첫 번째 항목을 클릭합니다.
예시 DAG의 개별 태스크에 대한 정보를 자세히 보여주는 DAG 실행 세부정보가 표시됩니다.
DAG 실행 로그 섹션에는 DAG 실행의 모든 태스크 로그가 나열됩니다. 로그에서
echo
명령어의 출력을 볼 수 있습니다.
삭제
이 페이지에서 사용한 리소스의 비용이 Google Cloud 계정에 청구되지 않도록 하려면 다음 단계를 따르세요.
이 튜토리얼에서 사용된 리소스를 삭제합니다.
Cloud Composer 환경을 삭제합니다.
Google Cloud 콘솔에서 환경 페이지로 이동합니다.
example-environment
를 선택하고 삭제를 클릭합니다.환경이 삭제될 때까지 기다립니다.
환경의 버킷을 삭제합니다. Cloud Composer 환경을 삭제하면 버킷이 삭제되지 않습니다.
Google Cloud 콘솔에서 저장소 > 브라우저 페이지로 이동합니다.
해당 환경의 버킷을 선택하고 삭제를 클릭합니다. 예를 들어 이 버킷의 이름을
us-central1-example-environ-c1616fe8-bucket
으로 지정할 수 있습니다.
다음 단계