Mit Slot-Reservierungen arbeiten
Mit der BigQuery Reservations API können Sie dedizierte Slots (sogenannte Zusicherungen) kaufen und Slot-Pools erstellen (sogenannte Reservierungen und diesen Reservierungen Projekte, Ordner und Organisationen zuweisen.
Mit Reservierungen können Sie einer Arbeitslast eine bestimmte Anzahl an Slots zuweisen. Beispielsweise kann es sein, dass eine Produktionsarbeitslast nicht mit Testarbeitslasten für Slots konkurrieren soll. Sie können eine Reservierung mit dem Namen prod erstellen und Ihre Produktionsarbeitslasten dieser Reservierung zuweisen. Weitere Informationen finden Sie unter Reservierungen.
Reservierungen erstellen
Erforderliche Berechtigungen
Zum Erstellen einer Reservierung benötigen Sie die folgende IAM-Berechtigung (Identity and Access Management):
bigquery.reservations.createfür das Verwaltungsprojekt, das die Eigentumsrechte für die Zusicherungen verwaltet.
Jede der folgenden vordefinierten IAM-Rollen enthält diese Berechtigung:
BigQuery Resource EditorBigQuery Resource Admin
Weitere Informationen zu IAM-Rollen in BigQuery finden Sie unter Vordefinierte Rollen und Berechtigungen.
Reservierung mit dedizierten Slots erstellen
Wählen Sie eine der folgenden Optionen aus:
Console
Rufen Sie in der Cloud de Confiance Console die Seite "BigQuery" auf.
Klicken Sie im Navigationsmenü auf Kapazitätsverwaltung.
Klicken Sie auf Reservierung erstellen.
Geben Sie im Feld Name der Reservierung einen Namen für die Reservierung ein.
Wählen Sie in der Liste Standort einen Standort aus. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.
Wählen Sie in der Liste Edition die Ausgabe aus. BigQuery-Versionsfunktionen wie Autoscaling sind nur innerhalb einer Version verfügbar. Weitere Informationen finden Sie unter Einführung in BigQuery-Versionen.
Wählen Sie in der Liste Maximale Reservierungsgröße die maximale Reservierungsgröße aus.
Optional: Geben Sie im Feld Referenz-Slots die Anzahl der Referenz-Slots für die Reservierung ein.
Die Anzahl der verfügbaren Autoscaling-Slots wird bestimmt, indem der Wert für Referenz-Slots vom Wert für Maximale Reservierungsgröße abgezogen wird. Wenn Sie beispielsweise eine Reservierung mit 100 Referenz-Slots und einer maximalen Reservierungsgröße von 400 erstellen, hat Ihre Reservierung 300 Autoscaling-Slots. Weitere Informationen zu Referenz-Slots finden Sie unter Reservierungen mit Slots für Referenz und Autoscaling verwenden.
Wenn Sie die Freigabe inaktiver Slots deaktivieren und nur die angegebene Slotkapazität verwenden möchten, klicken Sie auf die Schaltfläche Inaktive Slots ignorieren.
Klicken Sie zum Erweitern des Abschnitts Erweiterte Einstellungen auf den Erweiterungspfeil.
Optional: Um die Zielnebenläufigkeit von Jobs festzulegen, klicken und aktivieren Sie die Schaltfläche Automatische Zielnebenläufigkeit von Jobs überschreiben und geben Sie die Zielnebenläufigkeit von Jobs ein.
Die Aufschlüsselung der Slots wird in der Tabelle Kostenschätzung angezeigt. In der Tabelle Kapazitätsübersicht wird eine Zusammenfassung der Reservierung angezeigt.
Klicken Sie auf Speichern.
Die neue Reservierung ist auf dem Tab Slot-Reservierungen zu sehen.
SQL
Verwenden Sie zum Erstellen einer Reservierung die DDL-Anweisung CREATE RESERVATION.
Öffnen Sie in der Cloud de Confiance Console die Seite BigQuery.
Geben Sie im Abfrageeditor die folgende Anweisung ein:
CREATE RESERVATION `ADMIN_PROJECT_ID.region-LOCATION.RESERVATION_NAME` OPTIONS ( slot_capacity = NUMBER_OF_BASELINE_SLOTS, edition = EDITION, autoscale_max_slots = NUMBER_OF_AUTOSCALING_SLOTS);
Ersetzen Sie Folgendes:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressource gehörtLOCATION: Der Standort der Reservierung. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.RESERVATION_NAME: der Name der ReservierungDer Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.
NUMBER_OF_BASELINE_SLOTS: die Anzahl der Basisslots, die dieser Reservierung zugewiesen werden sollen Sie können die Optionenslot_capacityundeditionnicht in derselben Reservierung festlegen.EDITION: die Version der Reservierung. Wenn Sie einer Ausgabe eine Reservierung zuweisen, ändern sich die Funktion und die Preise. Weitere Informationen finden Sie unter Einführung in BigQuery-Editing.NUMBER_OF_AUTOSCALING_SLOTS: die Anzahl der Autoscaling-Slots, die der Reservierung zugewiesen sind. Dieser Wert entspricht dem Wert der maximalen Reservierungsgröße abzüglich der Anzahl der Referenzslots.
Klicken Sie auf Ausführen.
Informationen zum Ausführen von Abfragen finden Sie unter Interaktive Abfrage ausführen.
bq
Verwenden Sie zum Erstellen einer Reservierung den Befehl bq mk mit dem Flag --reservation:
bq mk \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION \
--reservation \
--slots=NUMBER_OF_BASELINE_SLOTS \
--ignore_idle_slots=false \
--edition=EDITION \
--autoscale_max_slots=NUMBER_OF_AUTOSCALING_SLOTS \
--max_slots=MAXIMUM_NUMBER_OF_SLOTS
--scaling_mode=SCALING_MODE
RESERVATION_NAME
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-IDLOCATION: Der Standort der Reservierung. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.NUMBER_OF_BASELINE_SLOTS: die Anzahl der Basisslots, die dieser Reservierung zugewiesen werden sollenRESERVATION_NAME: der Name der Reservierung. Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.EDITION: die Version der Reservierung. Wenn Sie einer Ausgabe eine Reservierung zuweisen, ändern sich die Funktion und die Preise. Weitere Informationen finden Sie unter Einführung in BigQuery-Editing.NUMBER_OF_AUTOSCALING_SLOTS: die Anzahl der Autoscaling-Slots, die der Reservierung zugewiesen sind. Dieser Wert entspricht dem Wert der maximalen Reservierungsgröße abzüglich der Anzahl der Referenzslots. Dies kann nicht mit den Flags--max_slotsoder--scaling_modekonfiguriert werden.MAXIMUM_NUMBER_OF_SLOTS: die maximale Anzahl an Slots, die die Reservierung nutzen kann. Dieser Wert muss mit dem Flag--scaling_modekonfiguriert werden (Vorabversion).SCALING_MODE: Der Skalierungsmodus der Reservierung. Die Optionen sindALL_SLOTS,IDLE_SLOTS_ONLYoderAUTOSCALE_ONLY. Dieser Wert muss mit dem Flag--scaling_modekonfiguriert werden (Vorabversion).
Weitere Informationen zum Flag --ignore_idle_slots finden Sie unter Inaktive Slots. Der Standardwert ist false.
Terraform
Verwenden Sie die Ressource google_bigquery_reservation:
Richten Sie zur Authentifizierung bei BigQuery die Standardanmeldedaten für Anwendungen ein. Weitere Informationen finden Sie unter Authentifizierung für Clientbibliotheken einrichten.
Im folgenden Beispiel wird eine Reservierung mit dem Namen my-reservation erstellt:
Führen Sie die Schritte in den folgenden Abschnitten aus, um Ihre Terraform-Konfiguration auf ein Cloud de Confiance -Projekt anzuwenden.
Cloud Shell vorbereiten
- Rufen Sie Cloud Shell auf.
-
Legen Sie das Standardprojekt Cloud de Confiance fest, auf das Sie Ihre Terraform-Konfigurationen anwenden möchten.
Sie müssen diesen Befehl nur einmal pro Projekt und in jedem beliebigen Verzeichnis ausführen.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Umgebungsvariablen werden überschrieben, wenn Sie in der Terraform-Konfigurationsdatei explizite Werte festlegen.
Verzeichnis vorbereiten
Jede Terraform-Konfigurationsdatei muss ein eigenes Verzeichnis haben (auch als Stammmodul bezeichnet).
-
Erstellen Sie in Cloud Shell ein Verzeichnis und eine neue Datei in diesem Verzeichnis. Der Dateiname muss die Erweiterung
.tfhaben, z. B.main.tf. In dieser Anleitung wird die Datei alsmain.tfbezeichnet.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
Wenn Sie einer Anleitung folgen, können Sie den Beispielcode in jedem Abschnitt oder Schritt kopieren.
Kopieren Sie den Beispielcode in das neu erstellte
main.tf.Kopieren Sie optional den Code aus GitHub. Dies wird empfohlen, wenn das Terraform-Snippet Teil einer End-to-End-Lösung ist.
- Prüfen und ändern Sie die Beispielparameter, die auf Ihre Umgebung angewendet werden sollen.
- Speichern Sie die Änderungen.
-
Initialisieren Sie Terraform. Dies ist nur einmal für jedes Verzeichnis erforderlich.
terraform init
Fügen Sie optional die Option
-upgradeein, um die neueste Google-Anbieterversion zu verwenden:terraform init -upgrade
Änderungen anwenden
-
Prüfen Sie die Konfiguration und prüfen Sie, ob die Ressourcen, die Terraform erstellen oder aktualisieren wird, Ihren Erwartungen entsprechen:
terraform plan
Korrigieren Sie die Konfiguration nach Bedarf.
-
Wenden Sie die Terraform-Konfiguration an. Führen Sie dazu den folgenden Befehl aus und geben Sie
yesan der Eingabeaufforderung ein:terraform apply
Warten Sie, bis Terraform die Meldung „Apply complete“ anzeigt.
- Öffnen Sie Ihr Cloud de Confiance Projekt, um die Ergebnisse aufzurufen. Rufen Sie in der Cloud de Confiance Console Ihre Ressourcen in der Benutzeroberfläche auf, um sicherzustellen, dass Terraform sie erstellt oder aktualisiert hat.
Python
Vorhersagbare Reservierung erstellen
Bevor Sie eine Reservierung mit einer maximalen Anzahl von Slots erstellen, müssen Sie zuerst reservierungsbasierte Fairness aktivieren.
Reservierungsbasierte Fairness aktivieren
Wenn Sie die reservierungsbasierte Fairness aktivieren möchten, setzen Sie das enable_reservation_based_fairness-Flag auf true.
Wenn Sie die auf Reservierungen basierende Fairness für ein Projekt aktualisieren möchten, benötigen Sie die Berechtigung bigquery.config.update für das Projekt, in dem die Reservierungen verwaltet werden. Die vordefinierte Rolle BigQuery Admin enthält diese Berechtigung.
Weitere Informationen zum Aktualisieren der Standardkonfiguration eines Projekts finden Sie unter Konfigurationseinstellungen verwalten.
ALTER PROJECT `PROJECT_NAME` SET OPTIONS ( `region-LOCATION.enable_reservation_based_fairness`= true);
Ersetzen Sie Folgendes:
- PROJECT_NAME: die Projekt-ID des Administrationsprojekts
- LOCATION: der Standort der Reservierung
Vorhersagbare Reservierung erstellen
Wenn Sie eine vorhersagbare Reservierung mit einer maximalen Anzahl von Slots erstellen möchten, wählen Sie eine der folgenden Optionen aus:
Console
Rufen Sie in der Cloud de Confiance Console die Seite "BigQuery" auf.
Rufen Sie im Navigationsbereich den Abschnitt Kapazitätsverwaltung auf und klicken Sie dann auf Reservierung erstellen.
Geben Sie im Feld Name der Reservierung einen Namen für die Reservierung ein.
Wählen Sie in der Liste Standort einen Standort aus. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.
Wählen Sie in der Liste Edition die Ausgabe aus. Autoscaling ist nur innerhalb einer Version verfügbar. Weitere Informationen finden Sie unter Informationen zu BigQuery-Versionen.
Wählen Sie in der Liste Maximale Reservierungsgröße die maximale Reservierungsgröße aus.
Optional: Geben Sie im Feld Referenz-Slots die Anzahl der Referenz-Slots für die Reservierung ein.
Die Anzahl der verfügbaren Autoscaling-Slots wird bestimmt, indem der Wert für Referenz-Slots vom Wert für Maximale Reservierungsgröße abgezogen wird. Wenn Sie beispielsweise eine Reservierung mit 100 Referenz-Slots und einer maximalen Reservierungsgröße von 400 erstellen, hat Ihre Reservierung 300 Autoscaling-Slots. Weitere Informationen zu Referenz-Slots finden Sie unter Reservierungen mit Slots für Referenz und Autoscaling verwenden.
Wenn Sie die Freigabe inaktiver Slots deaktivieren und nur die angegebene Slotkapazität verwenden möchten, klicken Sie auf die Schaltfläche Inaktive Slots ignorieren.
Klicken Sie zum Erweitern des Abschnitts Erweiterte Einstellungen auf den Erweiterungspfeil.
- Wählen Sie in der Liste Wie werden inaktive Slots verwendet? die Konfigurationsoption aus.
Die Aufschlüsselung der Slots wird in der Tabelle Kostenschätzung angezeigt. In der Tabelle Kapazitätsübersicht wird eine Zusammenfassung der Reservierung angezeigt.
Klicken Sie auf Speichern.
Die neue Reservierung ist auf dem Tab Slot-Reservierungen zu sehen.
bq
Verwenden Sie zum Erstellen einer vorhersagbaren Reservierung den Befehl bq mk mit dem Flag --reservation und legen Sie die Werte für max_slots und scaling_mode fest:
bq mk \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION \
--reservation \
--slots=NUMBER_OF_BASELINE_SLOTS \
--ignore_idle_slots=false \
--edition=EDITION \
--max_slots=MAXIMUM_NUMBER_OF_SLOTS \
--scaling_mode=SCALING_MODE
RESERVATION_NAME
Ersetzen Sie Folgendes:
ADMIN_PROJECT_ID: die Projekt-IDLOCATION: Der Standort der Reservierung. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.NUMBER_OF_BASELINE_SLOTS: die Anzahl der Basisslots, die dieser Reservierung zugewiesen werden sollenRESERVATION_NAME: der Name der ReservierungEDITION: die Version der Reservierung. Wenn Sie einer Ausgabe eine Reservierung zuweisen, ändern sich die Funktion und die Preise. Weitere Informationen finden Sie unter Einführung in BigQuery-Editing.MAXIMUM_NUMBER_OF_SLOTS: die maximale Anzahl an Slots, die die Reservierung nutzen kann. Dieser Wert muss mit dem Flag--scaling_modekonfiguriert werden.SCALING_MODE:SCALING_MODE: Der Skalierungsmodus der Reservierung. Die Optionen sindALL_SLOTS,IDLE_SLOTS_ONLYoderAUTOSCALE_ONLY. Dieser Wert muss mit dem Flagmax_slotskonfiguriert werden. Dieser Wert muss mit dem Flagignore_idle_slotsübereinstimmen. Weitere Informationen finden Sie unter Vorhersagbarkeit von Reservierungen.
Weitere Informationen zum Flag --ignore_idle_slots finden Sie unter Inaktive Slots. Der Standardwert ist false.
SQL
Verwenden Sie zum Erstellen einer vorhersagbaren Reservierung die DDL-Anweisung CREATE RESERVATION.
Öffnen Sie in der Cloud de Confiance Console die Seite BigQuery.
Geben Sie im Abfrageeditor die folgende Anweisung ein:
CREATE RESERVATION `ADMIN_PROJECT_ID.region-LOCATION.RESERVATION_NAME` OPTIONS ( slot_capacity = NUMBER_OF_BASELINE_SLOTS, edition = EDITION, ignore_idle_slots=IGNORE_IDLE_SLOTS max_slots = MAX_NUMBER_OF_SLOTS, scaling_mode = SCALING_MODE);
Ersetzen Sie Folgendes:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressource gehörtLOCATION: Der Standort der Reservierung. Wenn Sie einen BigQuery Omni-Standort auswählen, ist Ihre Versionsoption auf die Enterprise-Version beschränkt.RESERVATION_NAME: Der Name der Reservierung. Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten. Er muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.NUMBER_OF_BASELINE_SLOTS: die Anzahl der Basisslots, die dieser Reservierung zugewiesen werden sollen Sie können die Optionenslot_capacityundeditionnicht in derselben Reservierung festlegen.EDITION: die Version der Reservierung. Wenn Sie einer Ausgabe eine Reservierung zuweisen, ändern sich die Funktion und die Preise. Weitere Informationen finden Sie unter Einführung in BigQuery-Versionen.IGNORE_IDLE_SLOTS: Gibt an, ob die Reservierung inaktive Slots verwendet. Der Standardwert istfalse.MAX_NUMBER_OF_SLOTS: die maximale Anzahl an Slots, die die Reservierung nutzen kann. Dieser Wert muss mit der Optionscaling_modekonfiguriert werden.SCALING_MODE: Der Skalierungsmodus der Reservierung. Die Optionen sindALL_SLOTS,IDLE_SLOTS_ONLYoderAUTOSCALE_ONLY. Dieser Wert muss mit der Optionmax_slotskonfiguriert werden. Dieser Wert muss mit der Optionignore_idle_slotsübereinstimmen. Weitere Informationen finden Sie unter Vorhersagbarkeit von Reservierungen.
Klicken Sie auf Ausführen.
Informationen zum Ausführen von Abfragen finden Sie unter Interaktive Abfrage ausführen.
Weitere Informationen zu vorhersagbaren Reservierungen finden Sie unter Vorhersagbare Reservierungen.
Reservierungen aktualisieren
Sie können die folgenden Änderungen an einer Reservierung vornehmen:
- Ändern Sie die Reservierungsgröße, indem Sie Slots hinzufügen oder entfernen.
- Konfigurieren Sie, ob Abfragen in dieser Reservierung inaktive Slots verwenden.
- Ändern Sie die Anzahl der Baseline- oder Autoscaling-Slots, die einer Reservierung zugewiesen sind.
- Legen Sie die Zielnebenläufigkeit von Jobs fest.
Wenn Sie die Version einer Reservierung ändern möchten, müssen Sie zuerst die Reservierung löschen und dann eine Reservierung mit der aktualisierten Version erstellen.
Erforderliche Berechtigungen
Zum Aktualisieren einer Reservierung benötigen Sie die folgende IAM-Berechtigung (Identity and Access Management):
bigquery.reservations.updatefür das Verwaltungsprojekt, das die Eigentumsrechte für die Zusicherungen verwaltet.
Jede der folgenden vordefinierten IAM-Rollen enthält diese Berechtigung:
BigQuery AdminBigQuery Resource AdminBigQuery Resource Editor
Weitere Informationen zu IAM-Rollen in BigQuery finden Sie unter Vordefinierte Rollen und Berechtigungen.
Größe einer Reservierung ändern
Sie können Slots einer vorhandenen Reservierung hinzufügen oder aus ihr entfernen.
Console
Rufen Sie in der Cloud de Confiance Console die Seite "BigQuery" auf.
Klicken Sie im Navigationsmenü auf Kapazitätsverwaltung.
Klicken Sie auf den Tab Slot-Reservierungen.
Suchen Sie die Reservierung, die Sie aktualisieren möchten.
Maximieren Sie die Option Aktionen.
Klicken Sie auf Bearbeiten.
Geben Sie im Dialogfeld Maximale Reservierungsgröße auswählen die maximale Reservierungsgröße ein.
Geben Sie im Feld Referenz-Slots die Anzahl der Referenz-Slots ein.
Klicken Sie zum Erweitern des Abschnitts Erweiterte Einstellungen auf den Erweiterungspfeil.
Optional: Um die Zielnebenläufigkeit von Jobs festzulegen, klicken und aktivieren Sie die Schaltfläche Automatische Zielnebenläufigkeit von Jobs überschreiben und geben Sie die Zielnebenläufigkeit von Jobs ein.
Klicken Sie auf Speichern.
SQL
Verwenden Sie die DDL-Anweisung ALTER RESERVATION SET OPTIONS, um die Größe einer Reservierung zu ändern.
Öffnen Sie in der Cloud de Confiance Console die Seite BigQuery.
Geben Sie im Abfrageeditor die folgende Anweisung ein:
ALTER RESERVATION `ADMIN_PROJECT_ID.region-LOCATION.RESERVATION_NAME` SET OPTIONS ( slot_capacity = NUMBER_OF_BASELINE_SLOTS, autoscale_max_slots = NUMBER_OF_AUTOSCALING_SLOTS);
Ersetzen Sie Folgendes:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressource gehörtLOCATION: der Standort der Reservierung, z. B.europe-west9.RESERVATION_NAME: der Name der Reservierung Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.NUMBER_OF_BASELINE_SLOTS: die Anzahl der Slots, die der Reservierung zugewiesen werden sollen.NUMBER_OF_AUTOSCALING_SLOTS: die Anzahl der Autoscaling-Slots, die der Reservierung zugewiesen sind. Dieser Wert entspricht dem Wert der maximalen Reservierungsgröße abzüglich der Anzahl der Referenzslots.
Klicken Sie auf Ausführen.
Informationen zum Ausführen von Abfragen finden Sie unter Interaktive Abfrage ausführen.
bq
Verwenden Sie den Befehl bq update mit dem Flag --reservation, um die Größe einer Reservierung zu aktualisieren:
bq update \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION \
--slots=NUMBER_OF_BASELINE_SLOTS \
--autoscale_max_slots=NUMBER_OF_AUTOSCALING_SLOTS \
--reservation RESERVATION_NAME
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-IDLOCATION: der Standort der ReservierungNUMBER_OF_BASELINE_SLOTS: die Anzahl der Basisslots, die dieser Reservierung zugewiesen werden sollenRESERVATION_NAME: der Name der Reservierung. Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.NUMBER_OF_AUTOSCALING_SLOTS: die Anzahl der Autoscaling-Slots, die der Reservierung zugewiesen sind. Dieser Wert entspricht dem Wert der maximalen Reservierungsgröße abzüglich der Anzahl der Referenzslots.
Python
Konfigurieren, ob Abfragen inaktive Slots verwenden
Mit dem Flag --ignore_idle_slots wird gesteuert, ob Abfragen, die in einer Reservierung ausgeführt werden, inaktive Slots aus anderen Reservierungen verwenden können. Weitere Informationen finden Sie unter Inaktive Slots. Sie können diese Konfiguration für eine vorhandene Reservierung aktualisieren.
Verwenden Sie zum Aktualisieren einer Reservierung den Befehl bq update mit dem Flag --reservation. Im folgenden Beispiel wird für --ignore_idle_slots der Wert true festgelegt. Dies bedeutet, dass die Reservierung nur Slots nutzt, die der Reservierung zugewiesen sind.
bq update \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION \
--ignore_idle_slots=true \
--reservation RESERVATION_NAME
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-IDLOCATION: der Standort der ReservierungRESERVATION_NAME: der Name der Reservierung. Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.
Inaktive Slot-Konfiguration auflisten
So listen Sie die Einstellung inaktive Slots für eine Reservierung auf:
SQL
Fragen Sie die Spalte ignore_idle_slots der Ansicht INFORMATION_SCHEMA.RESERVATIONS_BY_PROJECT ab.
Öffnen Sie in der Cloud de Confiance Console die Seite BigQuery.
Geben Sie im Abfrageeditor die folgende Anweisung ein:
SELECT reservation_name, ignore_idle_slots FROM `ADMIN_PROJECT_ID.region-LOCATION`.INFORMATION_SCHEMA.RESERVATIONS_BY_PROJECT;
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressourcen gehörenLOCATION: der Standort der Reservierungen
Klicken Sie auf Ausführen.
Informationen zum Ausführen von Abfragen finden Sie unter Interaktive Abfrage ausführen.
bq
Führen Sie den Befehl bq ls mit dem Flag --reservation aus:
bq ls --reservation \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressourcen gehörenLOCATION: der Standort der Reservierungen
Das Feld ignoreIdleSlots enthält die Konfigurationseinstellung.
Reservierungen löschen
Wenn Sie eine Reservierung löschen, schlagen alle laufenden Jobs fehl, die Slots aus dieser Reservierung verwenden. Sie können Fehler vermeiden, indem Sie festlegen, dass laufende Jobs vor dem Löschen der Reservierung abgeschlossen werden.
Erforderliche Berechtigungen
Zum Löschen einer Reservierung benötigen Sie die folgende IAM-Berechtigung (Identity and Access Management):
bigquery.reservations.deletefür das Verwaltungsprojekt, das die Eigentumsrechte für die Zusicherungen verwaltet.
Jede der folgenden vordefinierten IAM-Rollen enthält diese Berechtigung:
BigQuery AdminBigQuery Resource AdminBigQuery Resource Editor
Weitere Informationen zu IAM-Rollen in BigQuery finden Sie unter Vordefinierte Rollen und Berechtigungen.
Eine Reservierung löschen
Console
Rufen Sie in der Cloud de Confiance Console die Seite "BigQuery" auf.
Klicken Sie im Navigationsmenü auf Kapazitätsverwaltung.
Klicken Sie auf den Tab Reservierungen.
Suchen Sie die Reservierung, die Sie löschen möchten.
Maximieren Sie die Option Aktionen.
Klicken Sie auf Löschen.
Klicken Sie im Dialogfeld Reservierung löschen auf Löschen.
SQL
Verwenden Sie die DDL-Anweisung DROP RESERVATION, um eine Reservierung zu löschen.
Öffnen Sie in der Cloud de Confiance Console die Seite BigQuery.
Geben Sie im Abfrageeditor die folgende Anweisung ein:
DROP RESERVATION `ADMIN_PROJECT_ID.region-LOCATION.RESERVATION_NAME`;
Ersetzen Sie Folgendes:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressource gehörtLOCATION: der Standort der ReservierungRESERVATION_NAME: die ID der Reservierung
Klicken Sie auf Ausführen.
Informationen zum Ausführen von Abfragen finden Sie unter Interaktive Abfrage ausführen.
bq
Verwenden Sie zum Löschen einer Reservierung den Befehl bq rm mit dem Flag --reservation:
bq rm \
--project_id=ADMIN_PROJECT_ID \
--location=LOCATION \
--reservation RESERVATION_NAME
Dabei gilt:
ADMIN_PROJECT_ID: die Projekt-ID des Administrationsprojekts, dem die Reservierungsressource gehörtLOCATION: der Standort der ReservierungRESERVATION_NAME: der Name der Reservierung. Der Name darf nur alphanumerische Zeichen in Kleinschreibung oder Bindestriche enthalten, muss mit einem Buchstaben beginnen und darf nicht mit einem Bindestrich enden. Die maximale Länge beträgt 64 Zeichen.
Python
Zugriff auf Reservierungen steuern
Sie können festlegen, welche Nutzer Zugriff auf bestimmte Reservierungen haben. Damit ein Nutzer eine Reservierung für seine Abfrage überschreiben kann, muss er die Berechtigung reservations.use für diese Reservierung haben.
Erforderliche Berechtigungen
Bitten Sie Ihren Administrator, Ihnen die IAM-Rolle Resource Editor (roles/bigquery.resourceEditor) für die Reservierungsressource zuzuweisen, damit Sie die Berechtigung erhalten, eine bestimmte Reservierung für Ihren Job anzugeben.
Weitere Informationen zum Zuweisen von Rollen finden Sie unter Zugriff auf Projekte, Ordner und Organisationen verwalten.
Diese vordefinierte Rolle enthält die Berechtigung reservations.use, die zum Angeben einer bestimmten Reservierung für Ihren Job erforderlich ist.
Sie können diese Berechtigung auch mit benutzerdefinierten Rollen oder anderen vordefinierten Rollen erhalten.
Zugriff auf eine Reservierung steuern
Verwenden Sie den Befehl bq
set-iam-policy, um den Zugriff auf eine bestimmte Reservierungsressource zu verwalten.
Wenn Sie den Zugriff auf mehrere Reservierungsressourcen verwalten möchten, verwenden Sie die Cloud de Confiance Console, um die Rolle „BigQuery-Ressourcenbearbeiter“ für das Projekt, den Ordner oder die Organisation zu gewähren. Wenn Sie die Rolle zuweisen, verwenden Sie eine IAM-Bedingung, um den Zugriff auf die Reservierungsressourcen zu ermöglichen, wenn die angegebenen Bedingungen erfüllt sind.
So steuern Sie den Zugriff auf Reservierungen:
Console
In der Cloud de Confiance Console können Sie den Zugriff auf mehrere Reservierungsressourcen über eine Bedingung zulassen.
Rufen Sie in der Cloud de Confiance Console die Seite IAM auf.
Wählen Sie ein Projekt, einen Ordner oder eine Organisation aus.
So weisen Sie einem Hauptkonto, das eine Rolle für die Reservierungsressourcen hat, die Rolle
bigquery.resourceEditorzu:Rufen Sie auf dem Tab Nach Hauptkonten ansehen das entsprechende Hauptkonto auf oder verwenden Sie die Option Filter, um das Hauptkonto zu finden.
Klicken Sie auf Hauptkonto bearbeiten.
Klicken Sie auf der Seite Rollen zuweisen auf Rollen hinzufügen.
Geben Sie im Feld Nach Rollen suchen
bigquery.resourceEditorein.Klicken Sie in den Suchergebnissen auf die Option BigQuery Resource Editor und dann auf Anwenden.
Klicken Sie auf Speichern.
Alternativ können Sie einem Hauptkonto, das keine Rolle für die Reservierungsressourcen hat, die Rolle
bigquery.resourceEditorzuweisen:Klicken Sie auf Zugriff gewähren.
Geben Sie auf der Seite Hauptkonten hinzufügen im Feld Neue Hauptkonten die Kennung des Hauptkontos ein, z. B.
//iam.googleapis.com/locations/global/workforcePools/my-pool/subject/my-user@example.com.Klicken Sie auf Rollen hinzufügen.
Geben Sie im Feld Nach Rollen suchen
bigquery.resourceEditorein.Klicken Sie in den Suchergebnissen auf die Option BigQuery Resource Editor und dann auf Anwenden.
Klicken Sie im Feld BigQuery-Ressourcen-Editor auf Bedingung hinzufügen.
Führen Sie auf der Seite Bedingung hinzufügen die folgenden Schritte aus:
Geben Sie Werte in die Felder Titel und Beschreibung ein.
Fügen Sie im Tool zur Bedingungserstellung die Bedingung hinzu. Wenn Sie beispielsweise eine Bedingung hinzufügen möchten, mit der die Rolle allen Reservierungsnamen zugewiesen wird, die mit
/reservation1enden, wählen Sie für Bedingungstyp die Option Name, für Operator die Option Endet mit und für Wert die Option/reservation1aus.Klicken Sie auf Speichern.
Klicken Sie auf Speichern.
bq
Im bq-Befehlszeilentool können Sie den Zugriff auf eine einzelne Reservierungsressource gewähren.
Verwenden Sie den Befehl bq
set-iam-policy, um Zugriff auf eine Reservierung zu gewähren:
bq set-iam-policy RESOURCE FILE_NAME
Ersetzen Sie Folgendes:
RESOURCE: Der Name der Reservierungsressource. Beispiel:projects/project1/locations/US/reservations/reservation1.FILE_NAME: Die Datei, die die Richtlinie im JSON-Format enthält. Das Format sollte der IAM-Richtlinienstruktur für Zulassungsrichtlinien entsprechen. Beispiel:{ "bindings": [ { "members": [ "user:my-user@example.com" ], "role": "roles/bigquery.resourceEditor" } ], "etag": "BwUjMhCsNvY=", "version": 1 }
Weitere Informationen zu IAM finden Sie unter Zugriff auf andere Ressourcen verwalten.