Standardkonfigurationen verwalten

In diesem Dokument wird beschrieben, wie Sie Standardkonfigurationseinstellungen auf Organisations- oder Projektebene create und abrufen.

Zur Verwaltung von Jobs können Sie in BigQuery Standardeinstellungen konfigurieren. Einstellungen, die diesen Dienst verwenden, werden auf Organisations- oder Projektebene konfiguriert, können jedoch auf Sitzungs- oder Jobebene überschrieben werden. Standardeinstellungen können Sie in Kombination mit zugehörigen Organisationsrichtlinien konfigurieren, um ein Standardverhalten zu erzwingen.

Preise

Für die Nutzung des BigQuery-Konfigurationsdienstes fallen keine zusätzlichen Gebühren an. Weitere Informationen finden Sie unter Preise.

Standardkonfigurationen

Sie können die folgenden Standardkonfigurationseinstellungen festlegen:

  • default_batch_query_queue_timeout_ms: Der Standardzeitraum in Millisekunden, in der eine Batchabfrage in die Warteschlange gestellt wird. Wenn nicht festgelegt, beträgt die Standardeinstellung 24 Stunden. Der Mindestwert beträgt 1 Millisekunde. Der Höchstwert beträgt 48 Stunden. Wenn Sie die Warteschlange für Batchabfragen deaktivieren möchten, setzen Sie den Wert auf -1.
  • default_column_name_character_map: Der Standardumfang und die Verarbeitung von Zeichen in Spaltennamen. Wenn nichts festgelegt ist, schlagen Ladejobs, die nicht unterstützte Zeichen in Spaltennamen verwenden, mit einer Fehlermeldung fehl. Bei einigen älteren Tabellen sind möglicherweise nicht unterstützte Zeichen in Spaltennamen ersetzt. Weitere Informationen finden Sie unter load_option_list.
  • default_interactive_query_queue_timeout_ms: Die Standardzeit in Millisekunden, in der eine interaktive Abfrage in die Warteschlange gestellt wird. Wenn nicht festgelegt, beträgt die Standardeinstellung sechs Stunden. Der Mindestwert beträgt 1 Millisekunde. Der Höchstwert beträgt 48 Stunden. Wenn Sie die Warteschlange für interaktive Abfragen deaktivieren möchten, setzen Sie den Wert auf -1.
  • default_kms_key_name: Der standardmäßige Cloud Key Management Service-Schlüssel zum Verschlüsseln von Tabellendaten, einschließlich temporärer oder anonymer Tabellen. Weitere Informationen finden Sie unter Vom Kunden verwaltete Cloud KMS-Schlüssel.
  • default_query_job_timeout_ms: Die Standardzeit, nach der ein Abfragejob das Zeitlimit überschreitet, einschließlich der Zeit, in der der Job in der Warteschlange steht, und der Zeit, in der er ausgeführt wird. Das Zeitlimit muss zwischen fünf Minuten und sechs Stunden liegen.
  • default_query_optimizer_options: Die verlaufsbasierten Abfrageoptimierungen. Mögliche Optionen:

    • 'adaptive=on': Verwenden Sie verlaufsbasierte Abfrageoptimierungen.
    • 'adaptive=off': Verwenden Sie keine verlaufsbasierten Abfrageoptimierungen.
    • NULL (Standardeinstellung): Verwenden Sie die Standardeinstellung für die verlaufsbasierte Abfrageoptimierung, die 'adaptive=off' entspricht.
  • default_time_zone: Standardzeitzone, die in zeitzonenabhängigen SQL-Funktionen verwendet wird, wenn keine Zeitzone als Argument angegeben ist. Diese Konfiguration gilt nicht für nach Zeiteinheit partitionierte Spalten (die die Zeitzone UTC verwenden), für Übertragungen des Storage Transfer Service oder das Laden von Daten mit dem bq-Befehlszeilentool. Weitere Informationen finden Sie unter Zeitzonen.

  • default_storage_billing_model ist das Standardspeicherabrechnungsmodell für neue Datasets. Legen Sie den Wert auf PHYSICAL fest, um physische Bytes bei der Berechnung der Speichergebühren zu verwenden, oder auf LOGICAL, um logische Byte zu verwenden. Eine Änderung des Standardspeicherabrechnungsmodells hat keine Auswirkungen auf vorhandene Datasets. Weitere Informationen finden Sie unter Abrechnungsmodelle für Speicher.

  • default_max_time_travel_hours: Das Standardzeitfenster für neue Datasets in Stunden. Die Dauer muss zwischen 48 und 168 (inklusiv) liegen und durch 24 teilbar sein. Eine Änderung der standardmäßigen maximalen Zeitreisestunden wirkt sich nicht auf vorhandene Datasets aus. Weitere Informationen finden Sie unter Zeitreisen.

Standardkonfigurationen erstellen

In diesem Abschnitt wird beschrieben, wie Sie eine Konfiguration erstellen.

Erforderliche Berechtigungen

Zum Erstellen einer Konfiguration benötigen Sie die IAM-Berechtigung (Identity and Access Management) bigquery.config.update. Die vordefinierte IAM-Rolle roles/bigquery.admin enthält die Berechtigungen, die Sie zum Erstellen einer Konfiguration benötigen.

Weitere Informationen zu IAM-Rollen und Berechtigungen in BigQuery finden Sie unter Vordefinierte Rollen und Berechtigungen.

Standardeinstellungen konfigurieren

Sie können die Standardeinstellungen auf Organisations- oder Projektebene mit den folgenden SQL-Anweisungen konfigurieren. Wenn Sie die Konfiguration erstellen, müssen Sie die Region angeben, in der sie gilt. Sie können nur eine Region für jede Anweisung verwenden.

Organisationseinstellungen konfigurieren

Mit der DDL-Anweisung ALTER ORGANIZATION SET OPTIONS können Sie die Organisationseinstellungen konfigurieren. Im folgenden Beispiel wird die Standardzeitzone auf America/Chicago, der Cloud KMS-Standardschlüssel auf einen benutzerdefinierten Schlüssel, das Standardzeitlimit für Abfragen auf 30 Minuten, das standardmäßige Zeitlimit für interaktive Abfragen auf 10 Minuten und das Standard-Zeitlimit für die Batch-Abfragewarteschlange auf 20 Minuten festgelegt:

ALTER ORGANIZATION
SET OPTIONS (
  `region-REGION.default_time_zone`= 'America/Chicago',
  -- Ensure all service accounts under the organization have permission to KMS_KEY
  `region-REGION.default_kms_key_name` = KMS_KEY,
  `region-REGION.default_query_job_timeout_ms` = 1800000,
  `region-REGION.default_interactive_query_queue_timeout_ms` = 600000,
  `region-REGION.default_batch_query_queue_timeout_ms` = 1200000,
  `region-REGION.default_storage_billing_model`= PHYSICAL,
  `region-REGION.default_max_time_travel_hours` = 72);

Ersetzen Sie Folgendes:

  • REGION: Die Region, die Ihrem Projekt oder Ihrer Organisation zugeordnet ist. Beispiel: us oder europe-west6.
  • KMS_KEY: ein benutzerdefinierter Cloud KMS-Schlüssel. Weitere Informationen zu Cloud KMS-Schlüsseln finden Sie unter Vom Kunden verwaltete Cloud KMS-Schlüssel.

Im folgenden Beispiel werden alle Standardeinstellungen auf Organisationsebene gelöscht.

ALTER ORGANIZATION
SET OPTIONS (
  `region-REGION.default_time_zone` = NULL,
  `region-REGION.default_kms_key_name` = NULL,
  `region-REGION.default_query_job_timeout_ms` = NULL,
  `region-REGION.default_interactive_query_queue_timeout_ms` = NULL,
  `region-REGION.default_batch_query_queue_timeout_ms` = NULL,
  `region-REGION.default_storage_billing_model`= NULL,
  `region-REGION.default_max_time_travel_hours` = NULL);

Projekteinstellungen konfigurieren

Mit der DDL-Anweisung ALTER PROJECT SET OPTIONS können Sie Projekteinstellungen konfigurieren. Die DDL-Anweisung ALTER PROJECT SET OPTIONS akzeptiert optional die Variable project_id. Wenn project_id nicht angegeben ist, wird standardmäßig das aktuelle Projekt verwendet, in dem die Abfrage ausgeführt wird. Im folgenden Beispiel wird die Standardzeitzone auf America/Los_Angeles, der Cloud KMS-Standardschlüssel auf einen Beispielschlüssel, das Standardzeitlimit für Abfragen auf 1 Stunde, das Standard-Zeitlimit für interaktive Abfragen auf 10 Minuten und das Standard-Zeitlimit für die Batch-Abfragewarteschlange auf 20 Minuten festgelegt:

ALTER PROJECT project_id
SET OPTIONS (
  `region-REGION.default_time_zone` = 'America/Los_Angeles',
  -- Ensure all service accounts under the project have permission to KMS_KEY
  `region-REGION.default_kms_key_name` = KMS_KEY,
  `region-REGION.default_query_job_timeout_ms` = 3600000,
  `region-REGION.default_interactive_query_queue_timeout_ms` = 600000,
  `region-REGION.default_batch_query_queue_timeout_ms` = 1200000,
  `region-REGION.default_storage_billing_model`= PHYSICAL,
  `region-REGION.default_max_time_travel_hours` = 72);

Im folgenden Beispiel werden alle Standardeinstellungen auf Projektebene gelöscht. Die Standardeinstellungen verwenden alle Standardeinstellungen auf Organisationsebene, sofern vorhanden. Andernfalls werden alle Standardeinstellungen auf die globale Standardeinstellung festgelegt.

ALTER PROJECT project_id
SET OPTIONS (
  `region-REGION.default_time_zone` = NULL,
  `region-REGION.default_kms_key_name` = NULL,
  `region-REGION.default_query_job_timeout_ms` = NULL,
  `region-REGION.default_interactive_query_queue_timeout_ms` = NULL,
  `region-REGION.default_batch_query_queue_timeout_ms` = NULL,
  `region-REGION.default_storage_billing_model`= NULL,
  `region-REGION.default_max_time_travel_hours` = NULL);

Konfigurationen auf Projektebene überschreiben Konfigurationen auf Organisationsebene. Konfigurationen auf Projektebene können wiederum durch Konfigurationen auf Sitzungsebene überschrieben werden, die wiederum durch Konfigurationen auf Jobebene überschrieben werden können.

Konfigurationswerte abrufen

Sie können die Standardkonfigurationseinstellungen für eine Organisation oder ein Projekt über das Informationsschema aufrufen. Es gibt drei verschiedene Ansichten zum Abfragen:

Es kann einige Minuten dauern, bis neue Konfigurationen wirksam werden und in der INFORMATION_SCHEMA-Ansicht widergespiegelt werden.

Erforderliche Berechtigungen

Zum Abrufen von Konfigurationswerten benötigen Sie die IAM-Berechtigung bigquery.config.get.

Jede der folgenden vordefinierten IAM-Rollen enthält die Berechtigungen, die Sie zum Abrufen der Konfiguration aus der INFORMATION_SCHEMA-Ansicht benötigen:

  • roles/bigquery.jobUser
  • roles/bigquery.dataEditor
  • roles/bigquery.dataUser

Weitere Informationen zu IAM-Rollen und Berechtigungen in BigQuery finden Sie unter Vordefinierte Rollen und Berechtigungen.

Beispiele

Führen Sie folgende Abfrage aus, um die Konfigurationen unter einer Organisation in der us-Region anzuzeigen:

SELECT * FROM region-us.INFORMATION_SCHEMA.ORGANIZATION_OPTIONS;

Führen Sie folgende Abfrage aus, um die effektiven Konfigurationen unter Ihrem Standardprojekt in der us-Region aufzurufen:

SELECT * FROM region-us.INFORMATION_SCHEMA.EFFECTIVE_PROJECT_OPTIONS;

Wenn Sie die Konfigurationen unter Ihrem Standardprojekt in der us-Region aufrufen möchten, führen Sie folgende Abfrage aus:

SELECT * FROM region-us.INFORMATION_SCHEMA.PROJECT_OPTIONS;