비밀번호

커뮤니티2

  • 맑음속초9.7
  • 2025.04.07(월)

데이터 엔지니어링데이터 엔지니어링

Airflow Dynamic Task Mapping 사용 시 map_index 지정하기

Airflow에는 Dynamic Task Mapping 기능을 통해 DAG 작성 시 필요한 task 개수를 미리 알 필요 없이

워크플로우가 현재 데이터를 기반으로 런타임에 여러 task를 실행할 수 있습니다. 마치 for 루프문 처럼 말이죠.

 

 

Dynamic Task의 기본적인 사용은 위와 같습니다. task의 expand 메소드를 통해 입력 데이터 개수만큼 런타임에서 TaskInstance를 생성하게 됩니다.

이렇게 하면 웹서버 UI에서 확인할 경우 다음을 볼 수 있습니다.

 

 

맵핑되었던 task별로 map index가 할당되어있습니다. 이는 임의로 0~n까지 맵핑됩니다.

동시에 실행되는 task 수가 많아지고 이를 모니터링하려면 이 화면에서 각 task를 미리 알아볼 수 있는 식별자가 필요할 것입니다. 이때 map index를 직접 지정할 수 있으면 어떨까요?

 

Airflow 2.9 버전부터는 이러한 기능을 제공합니다.

 

 

동적 맵핑되는 task의 데코레이터의 map_index_template 파라미터에 사용할 map index 템플릿을 지정합니다.

이후 task 코드 내에서 get_current_context() 메소드를 통해 컨텍스트를 가져온 후 지정한 템플릿을 작성합니다.

 

 

이렇게하여 map index에 템플릿이 적용된 인덱스를 넣을 수 있습니다.

사용 시 각 task를 파악할 수 있는 값을 지정한다면 task 수가 많아져도 모니터링하기 수월해 질 것입니다.

전체댓글0

검색결과는 총 25건 입니다.    글쓰기
1 2