Z tego przewodnika dowiesz się, jak interfejs Google Ads API obsługuje błędy i jak o nich informuje. Zrozumienie struktury i znaczenia błędów interfejsu API jest kluczowe do tworzenia niezawodnych aplikacji, które mogą sprawnie radzić sobie z problemami, od nieprawidłowych danych wejściowych po tymczasową niedostępność usługi.
Interfejs Google Ads API jest zgodny ze standardowym modelem błędów interfejsów API Google, który jest oparty na kodach stanu gRPC. Każda odpowiedź interfejsu API, która powoduje błąd, zawiera obiekt Status, który zawiera:
- Kod błędu w postaci liczby.
- komunikat o błędzie,
- Opcjonalne dodatkowe szczegóły błędu.
Kody błędów kanonicznych
Interfejs Google Ads API używa zestawu kanonicznych kodów błędów zdefiniowanych przez gRPC i HTTP. Te kody zawierają ogólne informacje o rodzaju błędu. Zawsze najpierw sprawdzaj ten kod numeryczny, aby zrozumieć podstawową naturę problemu.
W tabeli poniżej znajdziesz podsumowanie najczęstszych kodów, które możesz napotkać podczas korzystania z interfejsu Google Ads API:
| Kod gRPC | Kod HTTP | Nazwa typu wyliczeniowego | Opis | Wskazówki | 
|---|---|---|---|---|
| 0 | 200 | OK | Brak błędu; oznacza powodzenie. | Nie dotyczy | 
| 1 | 499 | CANCELLED | Operacja została anulowana, zwykle przez klienta. | Zwykle oznacza to, że klient przestał czekać. Sprawdź limity czasu po stronie klienta. | 
| 2 | 500 | UNKNOWN | Wystąpił nieznany błąd. Więcej szczegółów znajdziesz w komunikacie o błędzie lub w szczegółach. | Traktuj jako błąd serwera. Często można ponowić próbę z wycofywaniem. | 
| 3 | 400 | INVALID_ARGUMENT | Klient podał nieprawidłowy argument. Wskazuje to problem, który uniemożliwia interfejsowi API przetworzenie żądania, np. nieprawidłową nazwę zasobu lub nieprawidłową wartość. | Błąd klienta: sprawdź parametry żądania i upewnij się, że spełniają one wymagania interfejsu API. Szczegóły błędu zwykle zawierają informacje o tym, który argument był nieprawidłowy i w jaki sposób. Wykorzystaj te informacje, aby poprawić żądanie. Nie ponawiaj próby bez naprawienia żądania. | 
| 4 | 504 | DEADLINE_EXCEEDED | Termin upłynął przed wykonaniem operacji. | Błąd serwera: często przejściowy. Rozważ ponowienie próby z zastosowaniem wzrastającego czasu do ponowienia. | 
| 5 | 404 | NOT_FOUND | Nie znaleziono żądanego elementu, np. kampanii lub grupy reklam. | Błąd klienta: sprawdź, czy zasoby, do których próbujesz uzyskać dostęp, istnieją i czy ich identyfikatory są prawidłowe. Nie próbuj ponownie bez poprawienia. | 
| 6 | 409 | ALREADY_EXISTS | Encja, którą próbował utworzyć klient, już istnieje. | Błąd klienta: unikaj tworzenia zduplikowanych zasobów. Zanim spróbujesz utworzyć zasób, sprawdź, czy on istnieje. | 
| 7 | 403 | PERMISSION_DENIED | Element wywołujący nie ma uprawnień do wykonania określonej operacji. | Błąd klienta: sprawdź uwierzytelnianie, autoryzację i role użytkowników na koncie Google Ads. Nie próbuj ponownie bez rozwiązania problemu z uprawnieniami. | 
| 8 | 429 | RESOURCE_EXHAUSTED | Zasób został wyczerpany (np. przekroczono limit) lub system jest przeciążony. | Błąd klienta/serwera: zwykle wymaga odczekania. Wdróż wzrastający czas do ponowienia i potencjalnie zmniejsz szybkość wysyłania żądań. Zobacz Limity interfejsu API. | 
| 9 | 400 | FAILED_PRECONDITION | Operacja została odrzucona, ponieważ system nie znajduje się w stanie wymaganym do jej wykonania. Na przykład brakuje wymaganego pola. | Błąd klienta: żądanie jest prawidłowe, ale stan jest nieprawidłowy. Sprawdź szczegóły błędu, aby poznać przyczynę niepowodzenia warunku wstępnego. Nie próbuj ponownie bez poprawienia stanu. | 
| 10 | 409 | ABORTED | Operacja została przerwana, najczęściej z powodu problemu równoczesności, np. konfliktu transakcji. | Błąd serwera: często można ponowić próbę z krótkim wycofaniem. | 
| 11 | 400 | OUT_OF_RANGE | Operacja została podjęta poza prawidłowym zakresem. | Błąd klienta: popraw zakres lub indeks. | 
| 12 | 501 | UNIMPLEMENTED | Operacja nie jest zaimplementowana lub nie jest obsługiwana przez interfejs API. | Błąd klienta: sprawdź wersję interfejsu API i dostępne funkcje. Nie próbuj ponownie. | 
| 13 | 500 | INTERNAL | Wystąpił błąd wewnętrzny. Jest to ogólna kategoria problemów po stronie serwera. | Błąd serwera: zwykle można ponowić próbę z wzrastającym czasem do ponowienia. Jeśli problem będzie się powtarzał, zgłoś go. | 
| 14 | 503 | UNAVAILABLE | Usługa jest obecnie niedostępna. Jest to najprawdopodobniej stan przejściowy. | Błąd serwera: zdecydowanie zalecamy ponowienie próby z wzrastającym czasem do ponowienia. | 
| 15 | 500 | DATA_LOSS | Nieodwracalna utrata lub uszkodzenie danych. | Błąd serwera: rzadki. Wskazuje poważny problem. Nie próbuj ponownie. Jeśli problem będzie się powtarzał, zgłoś go. | 
| 16 | 401 | UNAUTHENTICATED | Żądanie nie ma prawidłowych danych uwierzytelniających. | Błąd klienta: sprawdź tokeny uwierzytelniające i dane logowania. Nie próbuj ponownie bez naprawienia uwierzytelniania. | 
Więcej informacji o tych kodach znajdziesz w przewodniku API Design Guide – kody błędów.
Szczegóły błędu
Oprócz kodu najwyższego poziomu interfejs Google Ads API udostępnia bardziej szczegółowe informacje o błędach w polu details obiektu Status. To pole często zawiera GoogleAdsFailure
proto, który zawiera listę poszczególnych obiektów GoogleAdsError.
Każdy obiekt GoogleAdsFailure zawiera:
- errors: lista obiektów- GoogleAdsError, z których każdy zawiera szczegółowe informacje o konkretnym błędzie, który wystąpił.
- request_id: unikalny identyfikator żądania, przydatny do debugowania i wsparcia;
Każdy obiekt GoogleAdsError zawiera:
- errorCode: bardziej szczegółowy kod błędu specyficzny dla interfejsu Google Ads API, np.- AuthenticationError.NOT_ADS_USER.
- message: czytelny opis konkretnego błędu.
- trigger: wartość, która spowodowała błąd (jeśli dotyczy).
- location: opisuje, w którym miejscu żądania wystąpił błąd, w tym ścieżki pól.
- details: dodatkowe szczegóły błędu, np. nieopublikowane przyczyny błędów.
Przykład szczegółów błędu
Gdy otrzymasz błąd, biblioteka klienta umożliwi Ci dostęp do tych szczegółów. Na przykład INVALID_ARGUMENT (kod 3) może mieć takie GoogleAdsFailure szczegóły:
{
  "code": 3,
  "message": "The request was invalid.",
  "details": [
    {
      "@type": "type.googleapis.com/google.ads.googleads.v17.errors.GoogleAdsFailure",
      "errors": [
        {
          "errorCode": {
            "fieldError": "REQUIRED"
          },
          "message": "The required field was not present.",
          "location": {
            "fieldPathElements": [
              { "fieldName": "operations" },
              { "fieldName": "create" },
              { "fieldName": "name" }
            ]
          }
        },
        {
          "errorCode": {
            "stringLengthError": "TOO_SHORT"
          },
          "message": "The provided string is too short.",
          "trigger": {
            "stringValue": ""
          },
          "location": {
            "fieldPathElements": [
              { "fieldName": "operations" },
              { "fieldName": "create" },
              { "fieldName": "description" }
            ]
          }
        }
      ]
    }
  ]
}
W tym przykładzie pomimo informacji na najwyższym poziomie INVALID_ARGUMENT szczegóły GoogleAdsFailure wskazują, że problem spowodowały pola name i description oraz dlaczego (REQUIRED i TOO_SHORT).
Znajdź szczegóły błędu
Sposób uzyskiwania dostępu do szczegółów błędu zależy od tego, czy używasz standardowych wywołań interfejsu API, częściowego niepowodzenia czy przesyłania strumieniowego.
Standardowe i strumieniowe wywołania interfejsu API
Gdy wywołanie interfejsu API zakończy się niepowodzeniem bez użycia częściowego niepowodzenia, w tym wywołania strumieniowe, obiekt GoogleAdsFailure jest zwracany jako część metadanych końcowych w nagłówkach odpowiedzi gRPC. Jeśli używasz REST do standardowych wywołań, w odpowiedzi HTTP zwracana jest wartość 
GoogleAdsFailure. Biblioteki klienta zwykle zgłaszają to jako wyjątek z atrybutem GoogleAdsFailure.
Częściowe niepowodzenie
Jeśli używasz częściowego
niepowodzenia, błędy dotyczące nieudanych
operacji są zwracane w polu partial_failure_error odpowiedzi, a nie w nagłówkach odpowiedzi. W tym przypadku element GoogleAdsFailure jest osadzony w obiekcie google.rpc.Status w odpowiedzi.
Zadania wsadowe
W przypadku przetwarzania wsadowego błędy poszczególnych operacji można znaleźć, pobierając wyniki zadania wsadowego po jego zakończeniu. Każdy wynik operacji będzie zawierać pole status z informacjami o błędzie, jeśli operacja się nie powiodła.
Identyfikator żądania
request-id to unikalny ciąg znaków, który identyfikuje Twoje żądanie interfejsu API i jest niezbędny do rozwiązywania problemów.
request-id znajdziesz w kilku miejscach:
- GoogleAdsFailure: jeśli wywołanie interfejsu API zakończy się niepowodzeniem i zostanie zwrócony kod- GoogleAdsFailure, będzie on zawierać- request_id.
- Metadane końcowe: w przypadku żądań zakończonych powodzeniem i niepowodzeniem w metadanych końcowych odpowiedzi gRPC dostępny jest parametr request-id.
- Nagłówki odpowiedzi: w przypadku udanych i nieudanych żądań wartość request-idjest też dostępna w nagłówkach odpowiedzi gRPC i HTTP, z wyjątkiem udanych żądań przesyłania strumieniowego.
- SearchGoogleAdsStreamResponse: w przypadku żądań przesyłania strumieniowego każda wiadomość zawiera pole- request_id.- SearchGoogleAdsStreamResponse
Podczas rejestrowania błędów lub kontaktowania się z zespołem pomocy pamiętaj, aby podać 
request-id, co ułatwi diagnozowanie problemów.
Sprawdzone metody obsługi błędów
Aby tworzyć odporne aplikacje, stosuj te sprawdzone metody:
- Sprawdź szczegóły błędu: zawsze analizuj pole - detailsobiektu- Status, zwracając szczególną uwagę na- GoogleAdsFailure. Szczegółowe informacje- errorCode,- messagei- locationw ramach- GoogleAdsErrordostarczają najbardziej przydatnych informacji do debugowania i opinii użytkowników.
- Odróżniaj błędy klienta od błędów serwera: - Błędy klienta: kody takie jak INVALID_ARGUMENT,NOT_FOUND,PERMISSION_DENIED,FAILED_PRECONDITION,UNAUTHENTICATED. Wymagają one zmian w żądaniu lub w stanie/danych logowania aplikacji. Nie ponawiaj żądania bez rozwiązania problemu.
- Błędy serwera: kody takie jak UNAVAILABLE,INTERNAL,DEADLINE_EXCEEDED,UNKNOWN. Wskazują one na tymczasowy problem z usługą API.
 
- Błędy klienta: kody takie jak 
- Wdróż strategię ponawiania: - Kiedy ponawiać próbę: ponawiaj próbę tylko w przypadku przejściowych błędów serwera, takich jak UNAVAILABLE,DEADLINE_EXCEEDED,INTERNAL,UNKNOWNiABORTED.
- Wzrastający czas do ponowienia: użyj algorytmu wzrastającego czasu do ponowienia, aby czekać coraz dłużej między ponownymi próbami. Pomaga to uniknąć przeciążenia już i tak obciążonej usługi. Na przykład odczekaj 1 sekundę, potem 2 sekundy, a następnie 4 sekundy, aż do osiągnięcia maksymalnej liczby ponownych prób lub łącznego czasu oczekiwania.
- Jitter: dodaj niewielką losową wartość „jitter” do opóźnień wycofywania, aby zapobiec problemowi „thundering herd”, w którym wielu klientów ponawia próbę jednocześnie.
 
- Kiedy ponawiać próbę: ponawiaj próbę tylko w przypadku przejściowych błędów serwera, takich jak 
- Dokładnie rejestruj błędy: rejestruj pełną odpowiedź o błędzie, w tym wszystkie szczegóły, a zwłaszcza identyfikator żądania. Te informacje są niezbędne do debugowania i zgłaszania problemów zespołowi pomocy Google. 
- Przekazywanie opinii użytkowników: na podstawie konkretnych kodów i wiadomości - GoogleAdsErrorprzekazuj użytkownikom aplikacji jasne i pomocne opinie. Na przykład zamiast „Wystąpił błąd” możesz podać „Wymagana jest nazwa kampanii” lub „Nie znaleziono podanego identyfikatora grupy reklam”.
Przestrzegając tych wytycznych, możesz skutecznie diagnozować i obsługiwać błędy zwracane przez interfejs Google Ads API, co pozwoli Ci tworzyć bardziej stabilne i przyjazne dla użytkownika aplikacje.