AWS Batch를 CloudWatch Events 규칙의 대상으로 사용하려면 어떻게 해야 합니까?

최종 업데이트 날짜: 2019년 12월 9일

AWS Batch를 Amazon CloudWatch Events 규칙의 대상으로 사용하고 싶습니다.

​해결 방법

다음 예제에서는 새로운 Amazon Simple Storage Service(Amazon S3) 버킷이 생성될 때 AWS Batch 작업을 제출하도록 Amazon CloudWatch를 구성하는 방법을 보여줍니다.

작업 정의 생성

1.    AWS Batch 콘솔을 엽니다.

2.    탐색 모음에서 AWS 리전을 선택합니다.

3.    탐색 창에서 작업 정의를 선택한 후 생성을 선택합니다.

4.    작업 정의 이름에 작업 정의의 고유한 이름을 입력합니다.

참고: 고유한 이름에 최대 128자의 문자(대문자 및 소문자), 숫자, 하이픈 및 밑줄을 사용할 수 있습니다.

5.    컨테이너 이미지amazonlinux를 입력합니다.

6.    명령에 다음을 입력합니다.

echo Ref::S3bucket

7.    vCPU2를 입력합니다.

8.    메모리(MiB)500을 입력합니다.

9.    다음을 선택한 다음, 생성을 선택합니다.

작업 대기열의 ARN 및 작업 정의 가져오기

1.    AWS Batch 콘솔을 엽니다.

2.    탐색 창에서 [Job queues(작업 대기열)]를 선택합니다.

3.    작업 대기열을 선택합니다.

4.    [Overview(개요)] 섹션에서 [Queue ARN(대기열 ARN)]을 복사한 다음 나중에 사용할 수 있도록 저장합니다.

5.    탐색 창에서 작업 정의를 선택한 후 이전에 생성한 작업 정의를 선택합니다.

6.    [Job definitions attributes(작업 정의 속성)] 섹션에서 [Job definition ARN(작업 정의 ARN)]을 복사한 다음 나중에 사용할 수 있도록 저장합니다.

CloudWatch Events 규칙 생성

1.    CloudWatch 콘솔을 엽니다.

2.    탐색 창에서 [Rules(규칙)]를 선택합니다.

3.    규칙 생성을 선택합니다.

4.    [Event Source(이벤트 소스)] 섹션에서 [Event Pattern(이벤트 패턴)]을 선택합니다.

5.    [Service Name(서비스 이름)]에서 [Simple Storage Service(S3)]를 선택합니다.

6.    이벤트 유형에서 버킷 수준 작업을 선택합니다.

참고: Amazon S3 객체 수준 작업에 대해 AWS Batch 작업을 트리거하려면(예: 새 객체가 기존 버킷에 업로드될 때) AWS CloudTrail 데이터 이벤트로 S3 버킷에 대해 객체 수준 로깅을 활성화하려면 어떻게 합니까?를 참조하십시오.

7.    [Any operation(모든 작업)]을 선택합니다.

8.    대상 섹션에서 대상 추가를 선택합니다.

9.    기본 메뉴에서 Batch 작업 대기열을 선택합니다.

10.    작업 대기열에 앞서 복사한 작업 대기열 ARN을 붙여 넣습니다.

11.    작업 정의에 앞서 복사한 작업 정의 ARN을 붙여 넣습니다.

12.    작업 이름에 AWS Batch 작업의 이름을 입력합니다.

13.    입력 구성 섹션에서 입력 변환기를 선택합니다.

14.    첫 번째 입력란에 이벤트가 트리거될 때 전송되는 S3 버킷 값을 입력합니다.

{"S3BucketNameValue":"$.detail.requestParameters.bucketName"}

참고: S3BucketNameValue를 고유한 값으로 바꿉니다.

15.    두 번째 입력란에 Batch 작업에 전달하는 파라미터 구조를 입력합니다.

{"Parameters" : {"S3bucket": S3BucketNameValue}}

참고: S3BucketNameValue를 고유한 값으로 바꿉니다. S3bucket을 AWS Batch 작업에 정의할 파라미터의 이름으로 바꿉니다.

16.    이 특정 리소스에 대해 새 역할 생성 또는 기존 역할 사용을 선택합니다.

참고: 기존 역할을 선택하는 경우 역할에 batch:SubmitJob 작업을 허용하는 AWS Identity and Access Management(IAM) 정책이 있어야 합니다.

17.    세부 정보 구성을 선택합니다.

18.    이름에 규칙의 이름을 입력합니다.

19.    상태에서 활성화됨 확인란을 선택합니다.

20.    규칙 생성을 선택합니다.

생성한 새 규칙 테스트

1.    Amazon S3 콘솔을 엽니다.

2.    버킷 생성을 선택합니다.

3.    버킷 이름 필드에 새 버킷의 고유한 DNS 준수 이름을 입력합니다.

4.    리전에서 CloudWatch Events 규칙을 생성한 리전과 동일한 리전을 선택합니다.

5.    생성을 선택합니다.

로그 확인

1.    AWS Batch 콘솔을 엽니다.

2.    탐색 창에서 [Jobs(작업)]를 선택합니다.

3.    [Status(상태)]가 [SUCCEEDED(성공)]인 작업을 선택합니다.

4.    작업 세부 정보 페이지의 시도 섹션에서 로그 보기를 선택합니다. 로그에 CloudWatch 콘솔의 버킷 이름이 표시됩니다.