오류는 다음과 같은 광범위한 카테고리로 분류됩니다.
- 인증
- 재시도 가능
- 유효성 검사
- 동기화 관련
이러한 카테고리는 가능한 모든 오류를 포함하지는 않으며 일부는 두 개 이상의 카테고리에 해당할 수 있지만, 앱의 오류 처리를 구성하기 위한 시작점으로 사용할 수 있습니다. 특정 오류에 관한 자세한 내용은 다음 리소스를 참고하세요.
- 일반 오류에서는 특정 오류에 관한 자세한 정보를 확인할 수 있습니다.
- API에서 사용하는 논리적 오류 모델에 관한 자세한 내용은 google.rpc.Status를 참고하세요.
인증 오류
인증은 사용자가 앱에 사용자를 대신하여 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
이면 앱에서 해당 광고를 로컬 데이터베이스에서 삭제된 것으로 표시해야 합니다. 이 방법으로 처리할 수 없는 오류는 앱에서 더 완전한 동기화 작업을 실행하거나 사람이 검토할 수 있도록 대기열에 추가될 수 있습니다.