API 구조

동영상: 2019년 워크숍의 서비스 및 리소스 대담 확인하기

이 가이드에서는 Google Ads API를 구성하는 주요 구성요소를 소개합니다. Google Ads API는 리소스서비스로 구성됩니다. 리소스는 Google Ads 항목을 나타내는 반면, 서비스는 Google Ads 항목을 검색하고 조작합니다.

객체 계층 구조

Google Ads 계정은 객체의 계층 구조로 볼 수 있습니다.

캠페인 모델

  • 계정의 최상위 리소스는 고객입니다.

  • 각 고객에게는 하나 이상의 활성 캠페인이 포함됩니다.

  • 각 캠페인에는 광고를 논리적 모음으로 그룹화하는 데 사용되는 광고 그룹이 하나 이상 포함됩니다.

  • 광고그룹 광고는 게재 중인 광고를 의미합니다. 광고 그룹당 하나의 광고 그룹 광고만 포함할 수 있는 앱 캠페인을 제외하고 각 광고 그룹에는 하나 이상의 광고 그룹 광고가 포함됩니다.

하나 이상의 AdGroupCriterion 또는 CampaignCriterion를 광고그룹 또는 캠페인에 연결할 수 있습니다. 이는 광고가 트리거되는 방식을 정의하는 기준을 나타냅니다.

키워드, 연령대, 위치 등 다양한 기준 유형이 있습니다. 캠페인 수준에서 정의된 기준은 캠페인 내의 다른 모든 리소스에 영향을 미칩니다. 캠페인 전체 예산 및 날짜를 지정할 수도 있습니다.

마지막으로 계정, 캠페인 또는 광고그룹 수준에서 광고 확장을 추가할 수 있습니다. 광고 확장을 사용하면 전화번호, 상세 주소, 프로모션 등의 추가 정보를 광고에 제공할 수 있습니다.

자료

리소스는 Google Ads 계정 내의 항목을 나타냅니다. 리소스의 두 가지 예는 CampaignAdGroup입니다.

객체 ID

Google Ads의 모든 객체는 고유 ID로 식별됩니다. 이러한 ID 중 일부는 모든 Google Ads 계정에서 전역적으로 고유하지만 다른 ID는 제한된 범위 내에서만 고유합니다.

객체 ID 고유성의 범위 전 세계적으로 고유한가요?
예산 ID 전 세계 지원됨
캠페인 ID 전 세계 지원됨
AdGroup ID 전 세계 지원됨
광고 ID 광고그룹 아니요. 하지만 (AdGroupId, AdId) 쌍은 전역적으로 고유합니다.
AdGroupCriterion ID입니다. 광고그룹 아니요. 하지만 (AdGroupId, CriterionId) 쌍은 전역적으로 고유합니다.
캠페인 기준 ID 실행 아니요. 하지만 (CampaignId, CriterionId) 쌍은 전역적으로 고유합니다.
광고 확장 실행 아니요. 하지만 (CampaignId, AdExtensionId) 쌍은 전역적으로 고유합니다.
피드 ID 글로벌 수준 지원됨
Feed Item ID 전 세계 지원됨
Feed Attribute ID 피드 아니요
Feed Mapping ID 전 세계 지원됨
라벨 ID 전 세계 지원됨
사용자 목록 ID 전 세계 지원됨

이러한 ID 규칙은 Google Ads 객체용 로컬 저장소를 설계할 때 유용할 수 있습니다.

일부 객체는 여러 항목 유형에 사용할 수 있습니다. 이러한 경우 객체에는 콘텐츠를 설명하는 type 필드가 포함됩니다. 예를 들어 AdGroupAd는 텍스트 광고, 호텔 광고, 지역 광고와 같은 객체를 나타낼 수 있습니다. 이 값은 AdGroupAd.ad.type 필드를 통해 액세스할 수 있으며 AdType 열거형 값을 반환합니다.

리소스 이름

각 리소스는 리소스와 상위 요소를 경로로 연결하는 resource_name 문자열로 고유하게 식별됩니다. 예를 들어 캠페인 리소스 이름의 형식은 다음과 같습니다.

customers/customer_id/campaigns/campaign_id

따라서 고객 ID가 1234567인 Google Ads 계정에서 ID가 987654인 캠페인의 경우 resource_name는 다음과 같습니다.

customers/1234567/campaigns/987654

서비스

서비스를 사용하면 Google Ads 항목을 검색하고 수정할 수 있습니다. 서비스에는 수정, 객체 및 통계 검색, 메타데이터 검색 서비스 등 세 가지 유형이 있습니다.

객체 수정 (변경)

이러한 서비스는 mutate 요청을 사용하여 연결된 리소스 유형의 인스턴스를 수정합니다. 또한 단일 리소스 인스턴스를 검색하는 get 요청을 제공하므로 리소스의 구조를 검사하는 데 유용할 수 있습니다.

서비스의 예:

mutate 요청에는 상응하는 operation 객체가 포함되어야 합니다. 예를 들어 CampaignService.MutateCampaigns 메서드는 CampaignOperation 인스턴스를 하나 이상 예상합니다. 작업에 대한 자세한 설명은 객체 변경 및 검사를 참조하세요.

동시 변경

하나의 Google Ads 객체는 2개 이상의 소스에서 동시에 수정할 수 없습니다. 이로 인해 여러 사용자가 앱에서 동일한 객체를 업데이트하거나 여러 스레드를 사용하여 Google Ads 객체를 동시에 변형하는 경우 오류가 발생할 수 있습니다. 여기에는 동일한 애플리케이션의 여러 스레드 또는 다른 애플리케이션 (예: 앱과 동시 Google Ads UI 세션)의 객체를 업데이트하는 작업이 포함됩니다.

API는 업데이트하기 전에 객체를 잠그는 방법을 제공하지 않습니다. 두 소스가 동시에 객체를 변경하려고 하면 API에서 DatabaseError.CONCURRENT_MODIFICATION_ERROR이 발생합니다.

비동기 및 동기 변경

Google Ads API 변경 메서드는 동기식입니다. API 호출은 객체가 변경된 후에만 응답을 반환하므로 각 요청에 대한 응답을 기다려야 합니다. 이 방법은 코드를 작성하기가 비교적 간단하지만, 프로세스가 호출이 완료될 때까지 기다려야 하는 경우 부하 분산에 부정적인 영향을 미치고 리소스를 낭비할 수 있습니다.

다른 접근 방식은 완료를 기다리지 않고 여러 서비스에서 일괄 작업을 실행하는 BatchJobService를 사용하여 객체를 비동기식으로 변경하는 것입니다. 일괄 작업이 제출되면 Google Ads API 서버에서 작업을 비동기식으로 실행하므로 프로세스가 다른 작업을 실행할 수 있게 됩니다. 주기적으로 작업 상태를 확인할 수 있습니다.

비동기 처리에 대한 자세한 내용은 일괄 처리 가이드를 참고하세요.

유효성 검사 변형

대부분의 변경 요청은 실제 데이터에 대해 호출을 실제로 실행하지 않고도 검증할 수 있습니다. 실제로 작업을 실행하지 않고도 누락된 매개변수와 잘못된 필드 값에 대한 요청을 테스트할 수 있습니다.

이 기능을 사용하려면 요청의 validate_only 부울 필드(선택사항)를 true로 설정하세요. 그러면 요청이 실행될 것처럼 완전히 검증되지만 최종 실행은 건너뜁니다. 오류가 발견되지 않으면 빈 응답이 반환됩니다. 유효성 검사에 실패하면 응답의 오류 메시지에 실패점이 표시됩니다.

validate_only는 광고가 일반적인 정책 위반인지 테스트하는 데 특히 유용합니다. 특정 단어, 구두점, 대문자 사용(영문), 길이 등의 정책을 위반하는 광고는 자동으로 거부됩니다. 잘못된 광고 하나로 인해 전체 배치가 실패할 수 있습니다. validate_only 요청 내에서 새 광고를 테스트하면 이러한 위반 사항을 확인할 수 있습니다. 실제 동작을 보려면 정책 위반 오류 처리 코드 예시를 참조하세요.

객체 및 성능 통계 가져오기

GoogleAdsService는 객체 및 성능 통계를 검색하기 위한 단일 통합 서비스입니다.

GoogleAdsService에 대한 모든 SearchSearchStream 요청에는 쿼리할 리소스, 검색할 리소스 속성과 성능 측정항목, 요청을 필터링하는 데 사용할 조건자, 성능 통계를 추가로 분석하는 데 사용할 세그먼트를 지정하는 쿼리가 필요합니다. 쿼리 형식에 대한 자세한 내용은 Google Ads 쿼리 언어 가이드를 참조하세요.

메타데이터 검색

GoogleAdsFieldService는 리소스에 사용 가능한 속성 및 데이터 유형과 같은 Google Ads API의 리소스에 대한 메타데이터를 검색합니다.

이 서비스는 GoogleAdsService에 쿼리를 작성하는 데 필요한 정보를 제공합니다. 편의를 위해 GoogleAdsFieldService에서 반환된 정보는 필드 참조 문서에서도 확인할 수 있습니다.