오류 유형

Google에서는 오류를 다음과 같은 광범위한 카테고리로 분류했습니다.

  • 인증
  • 재시도 가능
  • 검증
  • 동기화 관련

이러한 카테고리가 발생할 수 있는 모든 오류를 포괄하는 것은 아니며 일부는 둘 이상의 카테고리에 속할 수 있지만 앱의 오류 처리를 구조화하기 위한 시작점이 될 수 있습니다. 특정 오류에 대한 자세한 내용은 일반적인 오류를 참조하세요.

인증 오류

인증은 사용자가 앱을 대신하여 Google Ads에 액세스할 수 있도록 권한을 부여했는지 여부를 나타냅니다. 인증은 OAuth2 흐름에서 생성된 사용자 인증 정보를 통해 관리됩니다.

개발자가 제어할 수 없는 요인으로 인해 인증 오류가 발생하는 가장 일반적인 이유는 인증된 사용자가 앱에 부여한 권한을 취소했기 때문입니다. 예를 들어 앱에서 독립 클라이언트의 별도의 Google Ads 계정을 관리하고 클라이언트의 계정을 관리할 때 각 클라이언트로 별도로 인증하는 경우 클라이언트가 언제든지 앱의 액세스 권한을 취소할 수 있습니다. 액세스가 취소된 시점에 따라 API가 AuthenticationError.OAUTH_TOKEN_REVOKED 오류를 직접 반환하거나 클라이언트 라이브러리에 내장된 사용자 인증 정보 객체가 토큰 취소 예외를 발생시킬 수 있습니다. 두 경우 모두 앱에 클라이언트용 UI가 있는 경우 클라이언트 대신 사용할 수 있는 앱의 권한을 다시 설정하기 위해 OAuth2 흐름을 다시 시작하도록 요청할 수 있습니다.

Retryable 오류

TRANSIENT_ERROR 또는 INTERNAL_ERROR와 같은 일부 오류는 잠시 일시중지 후 요청을 재시도하여 해결할 수 있는 일시적인 문제를 나타낼 수 있습니다.

사용자가 시작한 요청의 경우 한 가지 전략은 UI에 오류를 즉시 표시하고 사용자에게 재시도를 트리거하는 옵션을 제공하는 것입니다. 또는 앱에서 먼저 자동으로 요청을 재시도하여 최대 재시도 횟수 또는 총 사용자 대기 시간에 도달한 후에만 UI에 오류를 노출할 수 있습니다.

백엔드에서 시작된 요청의 경우 앱은 최대 재시도 횟수까지 요청을 자동으로 재시도해야 합니다.

요청을 재시도할 때 지수 백오프 정책을 사용하세요. 예를 들어 첫 번째 재시도 전에 5초 동안 처음 일시중지했다면 두 번째 재시도 후 10초, 세 번째 재시도 후 20초 동안 일시중지할 수 있습니다. 지수 백오프는 API를 너무 공격적으로 호출하지 않도록 하는 데 도움이 됩니다.

유효성 검사 오류

유효성 검사 오류는 작업에 대한 입력이 허용되지 않았음을 나타냅니다. 예: PolicyViolationError, DateError, DateRangeError, StringLengthError, UrlFieldError

유효성 검사 오류는 사용자가 유효하지 않은 입력을 입력하여 사용자가 시작한 요청에서 가장 흔히 발생합니다. 이 경우 표시된 특정 API 오류에 따라 사용자에게 적절한 오류 메시지를 제공해야 합니다. 또한 API를 호출하기 전에 흔히 발생하는 실수가 있는지 사용자 입력에 대한 유효성을 검사할 수 있으므로 앱의 응답성과 API 사용 효율을 높일 수 있습니다. 백엔드 요청의 경우 앱은 실패한 작업을 사람이 검토하도록 대기열에 추가할 수 있습니다.

많은 Google Ads 앱에서는 Google Ads 객체를 저장하기 위해 로컬 데이터베이스를 유지관리합니다. 이 접근 방식의 한 가지 문제는 로컬 데이터베이스가 Google Ads의 실제 객체와 동기화되지 않을 수 있다는 것입니다. 예를 들어 사용자가 Google Ads에서 직접 광고그룹을 삭제하더라도 앱과 로컬 데이터베이스는 변경사항을 인식하지 못하므로 광고그룹이 존재하는 것처럼 API 호출을 계속합니다. 이러한 동기화 문제는 DUPLICATE_CAMPAIGN_NAME, DUPLICATE_ADGROUP_NAME, AD_NOT_UNDER_ADGROUP, CANNOT_OPERATE_ON_REMOVED_ADGROUPAD 등 다양한 오류로 나타날 수 있습니다.

사용자가 시작한 요청의 경우 한 가지 전략은 사용자에게 발생할 수 있는 동기화 문제를 알리고 Google Ads 객체의 관련 클래스를 검색하고 로컬 데이터베이스를 업데이트하는 작업을 즉시 실행한 다음 사용자에게 UI를 새로고침하라는 메시지를 표시하는 것입니다.

백엔드 요청의 경우 일부 오류는 앱에서 로컬 데이터베이스를 점진적으로 자동 수정할 수 있는 충분한 정보를 제공합니다. 예를 들어 CANNOT_OPERATE_ON_REMOVED_ADGROUPAD을 사용하면 앱이 해당 광고를 로컬 데이터베이스에서 삭제된 것으로 표시합니다. 이러한 방식으로 처리할 수 없는 오류가 발생하면 앱에서 보다 완벽한 동기화 작업을 시작하거나 사람이 검토할 수 있도록 대기열에 추가될 수 있습니다.