오류는 다음과 같은 광범위한 카테고리로 분류했습니다.
- 인증
- 재시도 가능
- 검증
- 동기화 관련
이러한 카테고리가 발생 가능한 오류를 모두 포괄하지는 않고 일부 오류는 둘 이상의 카테고리에 속할 수도 있지만, 앱의 오류 처리를 구성하는 데 출발점 역할을 할 수 있습니다. 특정 오류에 대한 자세한 내용은 일반적인 오류를 참조하세요.
인증 오류
인증은 사용자가 본인을 대신하여 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
가
있으면 앱이 로컬 데이터베이스에서 해당 광고를
삭제된 것으로 표시해야 합니다. 이러한 방식으로 처리할 수 없는 오류는 앱이 더 완전한 동기화 작업을 실행하거나 작업자가 검토할 수 있도록 대기열에 추가될 수 있습니다.