brunch

You can make anything
by writing

C.S.Lewis

by 비즈스프링 Aug 12. 2022

Elasticsearch를 사용한 매체통합솔루션 리포팅

매체통합솔루션에서 제공하는 수많은 리포트들은 어떤 과정을 통해 화면에 그려지고 있는지 궁금하지 않으신가요? 매체통합솔루션에서 신속한 리포팅이 가능한 이유는 바로 Elasticsearch를 사용하여 데이터를 빠르게 검색 및 집계하기 때문인데요, Elasticsearch에 대한 일반적인 이야기가 궁금하신 분들은 이전 포스팅을 참고해주세요.


▶ 광고매체 통합 리포트는 어떻게 만들어질까?

▶ Elasticsearch -온라인 서비스를 위한 빅데이터 플랫폼



이번 포스팅에서는 매체통합솔루션에서 Elasticsearch를 사용하여 리포팅을 진행하는 과정에 대해 공유하고자 합니다. 그럼 간단한 예제를 통해서 그 과정을 살펴보겠습니다.


리포팅 과정

매체통합솔루션의 '광고주/매체사별 대시보드' 리포트 (출처: BizSpring)


독자 여러분들의 이해를 돕기 위하여 매체통합리포트 > 대시보드 > 광고주/매체사별 대시보드 화면을 예시로 살펴보겠습니다. 광고주/매체사별 대시보드 화면의 리포팅 진행 과정을 간략히 표현하면 다음과 같습니다.


사용자가 서비스에서 대시보드 페이지를 클릭합니다.

서비스는 필터 데이터를 매핑하여 매체통합솔루션 서버로 API 요청을 보냅니다.

매체통합솔루션 서버는 전달 받은 필터 데이터로 쿼리를 생성하여 Elasticsearch에서 데이터를 검색합니다.

매체통합솔루션 서버는 서비스로 Elasticseach에서 반환 받은 데이터를 포함하여 API 응답을 보냅니다.

서비스는 응답 받은 데이터를 사용하여 차트 및 테이블을 출력합니다.



리포팅에 사용할 데이터 정의하기


먼저, 리포팅에 사용할 데이터를 Elasticsearch에 정의합니다. 해당 데이터는 차원(dimension) 데이터와 지표(metrics) 데이터를 모두 포함합니다. 광고주/매체사별 대시보드 화면에서 사용하는 필터 데이터는 광고주/사이트/광고 매체사/광고 플랫폼/광고 상품/일자인 것을 확인할 수 있습니다.


'광고주/매체사별 대시보드' 리포트의 필터 영역 (출처: BizSpring)



서버로 API 요청 보내기


서비스는 필터 데이터를 매핑하여 매체통합솔루션 서버로 API 요청을 보냅니다. 이때 응답 데이터를 바로 화면에 보여주기 위해 비동기로 요청합니다.


개발자 도구의 API 요청 화면 예시 (출처: BizSpring)



Elasticsearch에서 데이터 검색하기


매체통합솔루션 서버는 전달 받은 필터 데이터로 쿼리를 생성하여 Elasticsearch에서 데이터를 검색합니다. 이때 Elastic Java REST Client를 사용합니다.


Elasticsearch에서 데이터 검색 화면 예시


Request



Response




서버로부터 API 응답 받기


매체통합솔루션 서버는 Elasticseach에서 반환 받은 데이터를 포함하여 서비스로 API 응답을 보냅니다.


개발자 도구의 API 응답 화면 예시 (출처: BizSpring)


서비스는 응답 받은 데이터를 사용하여 차트 및 테이블을 출력합니다.



매체통합솔루션의 '광고주/매체사별 대시보드' 리포트 (출처: BizSpring)



매체통합솔루션에서 Elasticsearch를 사용하여 리포팅을 진행하는 과정에 대해 알아보았습니다. 비즈스프링의 마케팅 자동화 솔루션인 Growth Platform™에 대해 궁금한 점이 있다면 언제든지 문의해주세요.


✔️ 02-6919-5516 / ad@bizspring.co.kr





마케팅에서의 데이터 활용 기술과 인사이트
No.1 Data Partner for Data-Driven Growth
비즈스프링

공식 블로그 | 페이스북 | 네이버 블로그 | 유튜브 | 트위터 | 슬라이드쉐어




매거진의 이전글 BigQuery를 이용한 사용자 세그먼트

작품 선택

키워드 선택 0 / 3 0

댓글여부

afliean
브런치는 최신 브라우저에 최적화 되어있습니다. IE chrome safari