Fehlermeldungen
In diesem Dokument werden Fehlermeldungen beschrieben, die beim Arbeiten mit BigQuery auftreten können, einschließlich HTTP-Fehlercodes und vorgeschlagene Schritte zur Fehlerbehebung.
Weitere Informationen zu Abfragefehlern finden Sie unter Abfragefehler beheben.
Weitere Informationen zu Fehlern bei Streaming-Insert-Anweisungen finden Sie unter Fehlerbehebung bei Streaming-Insert-Anweisungen.
Fehlertabelle
Antworten von der BigQuery API enthalten einen HTTP-Fehlercode und ein Fehlerobjekt im Antworttext. Ein Fehlerobjekt ist normalerweise eines der folgenden:
- Ein
errors
-Objekt, das ein Array vonErrorProto
-Objekten enthält. - Ein
errorResults
-Objekt, das ein einzelnesErrorProto
-Objekt enthält.
Die Spalte Fehlermeldung in der folgenden Tabelle wird dem Attribut reason
in einem ErrorProto
-Objekt zugeordnet.
Diese Tabelle enthält nicht alle möglichen HTTP-Fehler oder andere Netzwerkfehler. Gehen Sie daher nicht davon aus, dass ein Fehlerobjekt in jeder Fehlerantwort von BigQuery vorhanden ist. Darüber hinaus erhalten Sie möglicherweise verschiedene Fehler oder Fehlerobjekte, wenn Sie die Cloud-Clientbibliotheken für die BigQuery API verwenden. Weitere Informationen finden Sie unter BigQuery API-Clientbibliotheken.
Wenn Sie einen HTTP-Antwortcode erhalten, der nicht in der folgenden Tabelle erscheint, weist der Antwortcode auf ein Problem oder ein erwartetes Ergebnis mit der HTTP-Anfrage hin. Die Antwortcodes im Bereich 5xx
zeigen einen serverseitigen Fehler an. Wenn Sie einen 5xx
-Antwortcode erhalten, wiederholen Sie die Anfrage später. In einigen Fällen kann der Antwortcode 5xx
von einem Zwischenserver wie einem Proxy zurückgegeben werden. Details zum Fehler finden Sie im Antworttext und in den Antwortheadern. Eine vollständige Liste der HTTP-Antwortcodes finden Sie unter HTTP-Antwortcodes.
Wenn Sie den Jobstatus mithilfe des bq-Befehlszeilentools prüfen, wird standardmäßig kein Fehlerobjekt zurückgegeben. Zur Anzeige des Fehlerobjekts und des entsprechenden reason
-Attributs, das der folgenden Tabelle zugeordnet wird, verwenden Sie das Flag --format=prettyjson
. Beispiel: bq --format=prettyjson show -j <job
id>
Wenn Sie das ausführliche Logging für das bq-Tool aufrufen möchten, verwenden Sie --apilog=stdout
.
Weitere Informationen zur Fehlerbehebung für das bq-Tool finden Sie unter Fehlerbehebung.
Fehlermeldung | HTTP-Code | Beschreibung | Fehlerbehebung | ||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
accessDenied | 403 | Dieser Fehler wird bei dem Versuch zurückgegeben, auf Ressourcen wie Datasets, Tabellen, Ansichten oder Jobs zuzugreifen, auf die Sie keinen Zugriff haben. Er wird außerdem zurückgegeben, wenn Sie versuchen, ein schreibgeschütztes Objekt zu ändern. | Wenden Sie sich an den Ressourceninhaber und bitten Sie ihn um Zugriff auf die Ressource für den Nutzer, der durch den principalEmail -Wert im Audit-Log des Fehlers identifiziert wird. |
||||||||||||||||||||||||||||||||||||||||||
attributeError | 400 | Dieser Fehler wird zurückgegeben, wenn es ein Problem mit dem Nutzercode gibt, bei dem ein bestimmtes Objektattribut aufgerufen wird, das nicht vorhanden ist. | Prüfen Sie, ob das Objekt, mit dem Sie arbeiten, das Attribut hat, auf das Sie zugreifen möchten. Weitere Informationen zu diesem Fehler finden Sie unter AttributeError. | ||||||||||||||||||||||||||||||||||||||||||
backendError | 500, 503 oder 504 | Dieser Fehler weist darauf hin, dass der Dienst derzeit nicht verfügbar ist. Dafür kann es verschiedene vorübergehende Gründe geben, darunter:
|
5xx-Fehler sind Probleme auf der Dienstseite, die der Client nicht beheben oder beeinflussen kann. Um die Auswirkungen von 5xx-Fehlern zu minimieren, müssen Sie Ihre Anfragen clientseitig mit abgeschnittenen exponentiellen Backoffs wiederholen. Weitere Informationen zum exponentiellen Backoff finden Sie unter Exponentieller Backoff.
Es gibt jedoch zwei Sonderfälle für die Behebung dieses Fehlers: jobs.get - und jobs.insert -Aufrufe.
Wenn Sie diesen Fehler beim Ausführen eines Wenn die Wiederholungsversuche nicht erfolgreich sind und die Probleme weiterhin bestehen, können Sie die Rate fehlgeschlagener Anfragen berechnen und den Support kontaktieren. Wenn eine bestimmte Anfrage an BigQuery wiederholt mit einem 5xx-Fehler fehlschlägt, auch wenn sie bei mehreren Neustartversuchen des Workflows mit exponentiellem Backoff wiederholt wird, sollten Sie das Problem an den Support eskalieren, damit es auf BigQuery-Seite behoben werden kann. Das gilt unabhängig von der insgesamt berechneten Fehlerrate. Achten Sie darauf, die Auswirkungen auf Ihr Unternehmen eindeutig zu kommunizieren, damit das Problem korrekt gesichtet werden kann. |
||||||||||||||||||||||||||||||||||||||||||
badRequest | 400 | Der Fehler 'UPDATE or DELETE statement over table <project.dataset.table> would
affect rows in the streaming buffer, which is not supported' kann auftreten, wenn einige kürzlich gestreamten Zeilen in einer Tabelle für DML-Vorgänge (DELETE , UPDATE , MERGE ) möglicherweise nicht verfügbar sind, in der Regel ein paar Minuten, in seltenen Fällen jedoch bis zu 90 Minuten. Weitere Informationen finden Sie unter Streaming-Datenverfügbarkeit und DML-Einschränkungen. |
Wenn Sie herausfinden möchten, ob Daten für DML-Vorgänge für Tabellen verfügbar sind, sehen Sie in der Antwort tables.get nach, ob der
Abschnitt „streamingBuffer“ vorhanden ist. Wenn der Abschnitt "streamingBuffer" nicht vorhanden ist, sind Tabellendaten für DML-Vorgänge verfügbar. Sie können das Feld streamingBuffer.oldestEntryTime auch verwenden, um das Alter von Datensätzen im Streaming-Zwischenspeicher zu ermitteln. |
||||||||||||||||||||||||||||||||||||||||||
billingNotEnabled | 403 | Dieser Fehler wird zurückgegeben, wenn die Abrechnung für das Projekt nicht aktiviert ist. | Aktivieren Sie die Abrechnung für das Projekt in der Trusted Cloud Console. | ||||||||||||||||||||||||||||||||||||||||||
billingTierLimitExceeded | 400 | Dieser Fehler wird zurückgegeben, wenn der Wert von statistics.query.billingTier für einen On-Demand-Job über 100 liegt. Dies tritt auf, wenn On-Demand-Abfragen zu viel CPU im Vergleich zur Menge der gescannten Daten verbrauchen. Eine Anleitung zum Prüfen von Jobdetails finden Sie unter Jobs verwalten.
|
Dieser Fehler tritt meist auf, wenn ein ineffizienter Cross Joins explizit oder implizit ausgeführt wird, beispielsweise aufgrund einer ungenauen Join-Bedingung. Diese Abfragetypen sind aufgrund des hohen Ressourcenverbrauchs nicht für On-Demand-Preise geeignet und lassen sich im Allgemeinen nicht gut skalieren. Sie können entweder die Abfrage optimieren oder das Preismodell kapazitätsbasiert (Slots) verwenden, um diesen Fehler zu beheben. Informationen zum Optimieren von Abfragen finden Sie unter SQL-Anti-Muster vermeiden. | ||||||||||||||||||||||||||||||||||||||||||
blockiert | 403 | Dieser Fehler wird zurückgegeben, wenn BigQuery den Vorgang, den Sie ausführen möchten, vorübergehend auf die Ablehnungsliste gesetzt hat, meist mit dem Ziel, einen Dienstausfall zu verhindern. | Wenden Sie sich an den Support, um weitere Informationen zu erhalten. | ||||||||||||||||||||||||||||||||||||||||||
duplicate | 409 | Dieser Fehler wird bei dem Versuch zurückgegeben, bereits vorhandene Jobs, Datasets oder Tabellen zu erstellen. Der Fehler wird auch zurückgegeben, wenn das Attribut writeDisposition eines Jobs auf WRITE_EMPTY gesetzt und die Zieltabelle, auf die der Job zugreift, bereits vorhanden ist. |
Benennen Sie die Ressource, die Sie erstellen möchten, um oder ändern Sie den Wert writeDisposition im Job. |
||||||||||||||||||||||||||||||||||||||||||
internalError | 500 | Dieser Fehler wird bei einem internen Fehler von BigQuery zurückgegeben. | Warten Sie entsprechend den Backoff-Anforderungen im BigQuery-Service Level Agreement und führen Sie den Vorgang dann noch einmal aus. Wenn der Fehler weiterhin auftritt, wenden Sie sich an den Support oder melden Sie einen Programmfehler über die BigQuery-Problemverfolgung. Sie können auch versuchen, die Häufigkeit dieses Fehlers durch Reservierungen zu reduzieren. | ||||||||||||||||||||||||||||||||||||||||||
ungültig | 400 |
Dieser Fehler wird zurückgegeben, wenn die Eingabe nicht wegen einer fehlerhaften Abfrage ungültig ist, sondern z. B. wegen nicht ausgefüllter Pflichtfelder oder wegen eines ungültigen Tabellenschemas. Bei ungültigen Abfragen wird der Fehler invalidQuery zurückgegeben.
|
|||||||||||||||||||||||||||||||||||||||||||
invalidQuery | 400 | Dieser Fehler wird zurückgegeben, wenn Sie versuchen, eine ungültige Abfrage auszuführen. | Prüfen Sie die Abfrage auf Syntaxfehler. Die Funktionsreferenz für Abfragen enthält Erläuterungen und Beispiele zur Erstellung gültiger Abfragen. | ||||||||||||||||||||||||||||||||||||||||||
invalidUser | 400 | Dieser Fehler wird zurückgegeben, wenn Sie versuchen, eine Abfrage mit ungültigen Nutzeranmeldedaten zu planen. | Aktualisieren Sie die Nutzeranmeldedaten, wie unter Abfragen planen erläutert. | ||||||||||||||||||||||||||||||||||||||||||
jobBackendError | 400 | Dieser Fehler wird zurückgegeben, wenn der Job erfolgreich erstellt wurde, aber mit einem internen Fehler fehlgeschlagen ist. Dieser Fehler kann in jobs.query oder jobs.getQueryResults angezeigt werden. |
Wiederholen Sie den Job mit einem neuen jobId . Wenn der Fehler weiterhin auftritt, wenden Sie sich an den Support. |
||||||||||||||||||||||||||||||||||||||||||
jobInternalError | 400 | Dieser Fehler wird zurückgegeben, wenn der Job erfolgreich erstellt wurde, aber mit einem internen Fehler fehlgeschlagen ist. Dieser Fehler kann in jobs.query oder jobs.getQueryResults angezeigt werden. |
Wiederholen Sie den Job mit einem neuen jobId . Wenn der Fehler weiterhin auftritt, wenden Sie sich an den Support. |
||||||||||||||||||||||||||||||||||||||||||
jobRateLimitExceeded | 400 | Dieser Fehler wird zurückgegeben, wenn der Job erfolgreich erstellt wurde, aber mit dem Fehler rateLimitExceeded fehlgeschlagen ist. Dieser Fehler kann in jobs.query oder jobs.getQueryResults angezeigt werden. |
Verwenden Sie exponentiellen Backoff, um die Anfragerate zu verringern, und wiederholen Sie den Job dann mit einem neuen jobId . |
||||||||||||||||||||||||||||||||||||||||||
notFound | 404 | Dieser Fehler wird zurückgegeben, wenn Sie eine nicht vorhandene Ressource angeben (ein Dataset, eine Tabelle oder ein Job) oder wenn der Standort in der Anfrage nicht mit dem Standort der Ressource übereinstimmt (z. B. dem Standort, an dem ein Job ausgeführt wird). Der Fehler kann auch auftreten, wenn Sie mit Tabelle-Decorators auf gelöschte Tabellen verweisen, an die kürzlich gestreamt wurde. | Korrigieren Sie die Ressourcennamen, geben Sie den Standort korrekt an oder warten Sie nach dem Streaming mindestens sechs Stunden, bevor Sie eine gelöschte Tabelle abfragen. | ||||||||||||||||||||||||||||||||||||||||||
notImplemented | 501 | Dieser Jobfehler wird zurückgegeben, wenn Sie versuchen, auf eine nicht implementierte Funktion zuzugreifen. | Wenden Sie sich an den Support, um weitere Informationen zu erhalten. | ||||||||||||||||||||||||||||||||||||||||||
proxyAuthenticationRequired | 407 | Dieser Fehler wird zwischen der Clientumgebung und dem Proxyserver zurückgegeben, wenn die Anfrage keine gültigen Anmeldedaten für den Proxyserver enthält. Weitere Informationen finden Sie unter 407 Proxy Authentication Required. | Die Fehlerbehebung ist spezifisch für Ihre Umgebung. Wenn dieser Fehler bei der Arbeit in Java auftritt, prüfen Sie, ob Sie die Eigenschaften jdk.http.auth.tunneling.disabledSchemes= und jdk.http.auth.proxying.disabledSchemes= ohne Wert nach dem Gleichheitszeichen festgelegt haben. |
||||||||||||||||||||||||||||||||||||||||||
quotaExceeded | 403 | Dieser Fehler wird zurückgegeben, wenn Ihr Projekt ein BigQuery-Kontingent oder ein benutzerdefiniertes Kontingent überschreitet oder wenn Sie keine Abrechnung eingerichtet haben und das kostenlose Kontingent für Abfragen überschreiten. | Informationen dazu, welches Kontingent überschritten wurde, sind über das Attribut message des Fehlerobjekts verfügbar. Wenn Sie ein BigQuery-Kontingent zurücksetzen oder erhöhen möchten, wenden Sie sich an den Support.
Zum Ändern eines benutzerdefinierten Kontingents können Sie eine Anfrage über die Seite Trusted Cloud console senden. Wenn Sie diesen Fehler bei Verwendung der BigQuery-Sandbox erhalten, können Sie ein Upgrade über die Sandbox ausführen.
Weitere Informationen finden Sie unter BigQuery-Kontingentfehler beheben. |
||||||||||||||||||||||||||||||||||||||||||
rateLimitExceeded | 403 | Dieser Fehler wird zurückgegeben, wenn Ihr Projekt eine kurzfristige Ratenbegrenzung überschreitet, weil zu viele Anfragen zu schnell gesendet werden. Informationen hierzu finden Sie beispielsweise unter Ratenbegrenzungen für Abfragejobs und Ratenbegrenzungen für API-Anfragen. | Verringern Sie die Anfragerate. Wenn Sie der Meinung sind, dass Ihr Projekt keines dieser Limits überschritten hat, wenden Sie sich an den Support. Weitere Informationen finden Sie unter BigQuery-Kontingentfehler beheben. |
||||||||||||||||||||||||||||||||||||||||||
resourceInUse | 400 | Dieser Fehler wird bei dem Versuch zurückgegeben, ein Dataset mit Tabellen oder einen gerade ausgeführten Job zu löschen. | Entfernen Sie vor dem Löschen die Tabellen aus dem Dataset bzw. warten Sie, bis der entsprechende Job abgeschlossen wurde. | ||||||||||||||||||||||||||||||||||||||||||
resourcesExceeded | 400 | Dieser Fehler wird zurückgegeben, wenn Ihr Job zu viele Ressourcen beansprucht. | Dieser Fehler wird zurückgegeben, wenn Ihr Job zu viele Ressourcen beansprucht. Informationen zur Fehlerbehebung finden Sie unter Fehlerbehebung bei Ressourcenfehlern aufgrund überschrittener Ressourcen. | ||||||||||||||||||||||||||||||||||||||||||
responseTooLarge | 403 | Dieser Fehler wird zurückgegeben, wenn die Ergebnisse Ihrer Abfrage die maximale Antwortgröße überschreiten. Manche Abfragen werden in mehreren Schritten ausgeführt. Dieser Fehler wird zurückgegeben, wenn die Antwort bei einem einzelnen Schritt zu groß ist, auch wenn das Endergebnis unterhalb des Maximums liegt. Dieser Fehler tritt oft auf, wenn in Abfragen eine ORDER BY -Klausel verwendet wird. |
Manchmal lässt sich das Problem durch Hinzufügen einer LIMIT -Klausel oder durch Entfernen der ORDER BY -Klausel beheben. Damit große Ergebnisse keine Probleme verursachen, setzen Sie das Attribut allowLargeResults auf true und geben Sie eine Zieltabelle an. Weitere Informationen finden Sie unter Große Abfrageergebnisse schreiben. |
||||||||||||||||||||||||||||||||||||||||||
Angehalten | 200 | Dieser Statuscode wird zurückgegeben, wenn ein Job abgebrochen wird. | |||||||||||||||||||||||||||||||||||||||||||
tableUnavailable | 400 | Für bestimmte BigQuery-Tabellen werden Daten benötigt, die von anderen Google-Produktteams verwaltet werden. Dieser Fehler gibt an, dass eine dieser Tabellen nicht verfügbar ist. | Wenn diese Fehlermeldung auftritt, können Sie die Anfrage noch einmal ausführen (siehe Vorschläge zur Fehlerbehebung für internalError) oder Sie wenden sich an das Google-Produktteam, das Ihnen Zugriff auf seine Daten gewährt hat. | ||||||||||||||||||||||||||||||||||||||||||
timeout | 400 | Der Job hat das Zeitlimit überschritten. | Sie sollten die Menge der bei Ihrem Vorgang ausgeführten Arbeit reduzieren, damit sie innerhalb des festgelegten Limits ausgeführt werden kann. Weitere Informationen finden Sie unter Beispiel für eine Fehlerantwort.
GET https://bigquery.googleapis.com/bigquery/v2/projects/12345/datasets/foo Response: [404] { "error": { "errors": [ { "domain": "global", "reason": "notFound", "message": "Not Found: Dataset myproject:foo" }], "code": 404, "message": "Not Found: Dataset myproject:foo" } } Rate der fehlgeschlagenen Anfragen und Betriebszeit berechnenDie meisten 500- und 503-Fehler lassen sich durch einen Wiederholungsversuch mit exponentiellem Backoff beheben. Wenn 500- und 503-Fehler weiterhin auftreten, können Sie die Gesamtrate fehlgeschlagener Anfragen und die entsprechende Betriebszeit berechnen, um sie mit dem BigQuery-Service Level Agreement (SLA) zu vergleichen und festzustellen, ob der Dienst wie erwartet funktioniert. Um die Gesamtrate fehlgeschlagener Anfragen in den letzten 30 Tagen zu berechnen, teilen Sie die Anzahl der fehlgeschlagenen Anfragen für einen bestimmten API-Aufruf oder eine bestimmte Methode in den letzten 30 Tagen durch die Gesamtzahl der Anfragen für diesen API-Aufruf oder diese Methode in den letzten 30 Tagen. Multiplizieren Sie diesen Wert mit 100, um den durchschnittlichen Prozentsatz fehlgeschlagener Anfragen über 30 Tage zu erhalten. Sie können beispielsweise Cloud Logging-Daten abfragen, um die Gesamtzahl der Ziehen Sie zuerst die Gesamtrate der fehlgeschlagenen Anfragen von 100% ab. Wenn dieser Wert größer oder gleich dem im BigQuery-SLA beschriebenen Wert ist, entspricht die Betriebszeit auch dem BigQuery-SLA. Wenn dieser Wert jedoch niedriger ist als der im SLA beschriebene Wert, berechnen Sie die Betriebszeit manuell. Um die Betriebszeit zu berechnen, müssen Sie die Anzahl der Minuten kennen, die als Dienstausfall gelten. Ein Dienstausfall ist ein Zeitraum von einer Minute mit einer Fehlerrate von mehr als 10 %, die gemäß den SLA-Definitionen berechnet wird. Um die Betriebszeit zu berechnen, ziehen Sie von der Gesamtzahl der Minuten der letzten 30 Tage die Gesamtzahl der Minuten ab, in denen der Dienst nicht verfügbar war. Teile die verbleibende Zeit durch die Gesamtzahl der Minuten der letzten 30 Tage und multipliziere diesen Wert mit 100, um den Prozentsatz der Betriebszeit über 30 Tage zu erhalten. Weitere Informationen zu den Definitionen und Berechnungen im Zusammenhang mit dem SLA finden Sie im BigQuery-Service Level Agreement (SLA). Wenn Ihr monatlicher Uptime-Prozentsatz größer oder gleich dem im BigQuery-SLA beschriebenen Wert ist, wurde der Fehler höchstwahrscheinlich durch ein vorübergehendes Problem verursacht. Sie können es also weiterhin mit exponentiellem Backoff versuchen. Wenn die Betriebszeit unter dem im SLA angegebenen Wert liegt, wenden Sie sich an den Support und geben Sie die beobachtete Gesamtrate der Fehler und die Berechnungen der Betriebszeit an. AuthentifizierungsfehlerBei Fehlern, die vom System zur Generierung von OAuth-Tokens ausgegeben werden, wird gemäß der Definition der OAuth2-Spezifikation das folgende JSON-Objekt zurückgegeben:
Der Fehler wird zusammen mit einem "HTTP
Fehler ansehenMit dem Log-Explorer können Sie Authentifizierungsfehler für bestimmte Jobs, Nutzer oder andere Bereiche aufrufen. Nachfolgend finden Sie einige Beispiele für Filter für den Log-Explorer, mit denen Sie Authentifizierungsfehler prüfen können.
Fehlermeldungen zu VerbindungenIn der folgenden Tabelle sind Fehlermeldungen aufgeführt, die aufgrund von zeitweiligen Verbindungsproblemen bei der Verwendung der Clientbibliotheken oder beim Aufrufen der BigQuery API aus Ihrem Code angezeigt werden können:
Trusted Cloud Console-FehlermeldungenIn der folgenden Tabelle sind Fehlermeldungen aufgeführt, die in derTrusted Cloud Console auftreten können.
|