Acquistare e gestire impegni per gli slot legacy

L'API BigQuery Reservation consente di acquistare slot dedicati (chiamati impegni��), creare pool di slot (chiamati prenotazioni��) e assegnare progetti, cartelle e organizzazioni a queste prenotazioni.

Un impegno di capacità è un acquisto di capacità di calcolo BigQuery per un periodo di tempo minimo. L'acquisto di un impegno di capacità è facoltativo quando crei una prenotazione con una versione, ma può offrire risparmi sui costi.

Gli impegni sono una risorsa di regione. Gli impegni acquistati in una regione o in più regioni non possono essere utilizzati in altre regioni o in più regioni. Gli impegni non possono essere spostati tra regioni o tra regioni e più regioni.

Abilita l'API Reservations

L'API BigQuery Reservation è diversa dall'API BigQuery esistente e deve essere abilitata separatamente. Per saperne di più, consulta Attivazione e disattivazione delle API.

  • Il nome dell'API è "API BigQuery Reservation"
  • L'endpoint per l'API BigQuery Reservation è bigqueryreservation.googleapis.com.

Abilita l'API.

Acquistare slot

Per riservare la capacità per un periodo di tempo minimo, puoi acquistare un impegno di capacità. In questo modo si ottiene uno sconto e si risparmiano costi. Per ulteriori informazioni sui costi specifici, consulta la pagina Prezzi di BigQuery.

Autorizzazioni obbligatorie

Per creare un impegno di capacità, devi disporre della seguente autorizzazione Identity and Access Management (IAM):

Ognuno dei seguenti ruoli IAM predefiniti include questa autorizzazione:

  • BigQuery Admin
  • BigQuery Resource Admin

Per saperne di più sui ruoli IAM in BigQuery, consulta Ruoli e autorizzazioni predefiniti.

Creare un impegno di capacità

Gli impegni sono una risorsa di regione. Gli impegni acquistati in una regione o in più regioni non possono essere utilizzati in altre regioni o in più regioni. Gli impegni non possono essere spostati tra regioni o tra regioni e multiregioni.

Console

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic su Crea impegno.

  4. In Configura:

    1. Seleziona la posizione.
    2. Nella sezione Modello di capacità, seleziona il modello di capacità.
    3. Seleziona la Durata dell'impegno, che specifica il tuo piano di impegno.
    4. Se acquisti un impegno annuale, seleziona il piano di rinnovo che vuoi che diventi effettivo alla scadenza dell'impegno:

      1. Non rinnovare e converti in un impegno mensile (impostazione predefinita). Quando l'impegno annuale scade, viene convertito in un impegno mensile.
      2. Rinnova annualmente. Alla scadenza dell'impegno annuale, questo viene rinnovato per un altro anno come impegno annuale.
      3. Non rinnovare e converti in slot flessibili. Quando l'impegno annuale scade, viene convertito in un impegno per slot flessibili.

      Per ulteriori informazioni, consulta Impegni di slot.

    5. Inserisci il numero di slot che vuoi acquistare.

    6. Fai clic su Avanti.

  5. Controlla la stima del costo del tuo acquisto.

  6. In Conferma e invia:

    1. Digita CONFIRM per confermare l'acquisto.
    2. Fai clic su Acquista per acquistare gli slot.
  7. Per visualizzare l'impegno, fai clic su Visualizza impegni slot. Dopo aver eseguito il provisioning della capacità, l'impegno di capacità richiesto ha uno stato verde.

La prima volta che acquisti capacità, viene creata una prenotazione default.

SQL

Per creare un impegno di capacità, utilizza l'istruzione DDL CREATE CAPACITY.

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nell'editor di query, inserisci la seguente istruzione:

    CREATE CAPACITY
      `ADMIN_PROJECT_ID.region-LOCATION.COMMITMENT_ID`
    OPTIONS (
      slot_count = NUMBER_OF_SLOTS,
      plan = 'PLAN_TYPE');

    Sostituisci quanto segue:

    • ADMIN_PROJECT_ID: l'ID progetto del progetto di amministrazione che manterrà la proprietà di questo impegno
    • LOCATION: la posizione dell'impegno
    • COMMITMENT_ID: l'ID dell'impegno

      Deve essere univoco per il progetto e la località. Deve iniziare e terminare con una lettera minuscola o un numero e contenere solo lettere minuscole, numeri e trattini.

    • NUMBER_OF_SLOTS: il numero di slot da acquistare
    • PLAN_TYPE: il tipo di piano, ad esempio FLEX, MONTHLY o ANNUAL.

  3. Fai clic su Esegui.

Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.

bq

Utilizza il comando bq mk con il flag --capacity_commitment per acquistare slot.

bq mk \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --capacity_commitment=true \
    --plan=PLAN_TYPE \
    --slots=NUMBER_OF_SLOTS

Sostituisci quanto segue:

  • ADMIN_PROJECT_ID: l'ID progetto del progetto di amministrazione che manterrà la proprietà di questo impegno
  • LOCATION: la posizione dell'impegno
  • PLAN_TYPE: il tipo di piano, ad esempio FLEX, MONTHLY o ANNUAL.
  • NUMBER_OF_SLOTS: il numero di slot da acquistare.

Visualizza impegni di capacità

Autorizzazioni obbligatorie

Per visualizzare gli impegni, devi disporre della seguente autorizzazione Identity and Access Management (IAM):

Ognuno dei seguenti ruoli IAM predefiniti include questa autorizzazione:

  • BigQuery Admin
  • BigQuery Resource Admin
  • BigQuery Resource Editor
  • BigQuery Resource Viewer
  • BigQuery User

Per saperne di più sui ruoli IAM in BigQuery, consulta Ruoli e autorizzazioni predefiniti.

Visualizza gli impegni di capacità per progetto

Per visualizzare gli impegni di capacità per progetto:

Console

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic sulla scheda Impegni slot. I tuoi impegni di capacità sono elencati nella tabella in Impegni.

SQL

Per visualizzare gli impegni per un progetto di amministrazione, esegui una query sulla visualizzazione INFORMATION_SCHEMA.CAPACITY_COMMITMENTS_BY_PROJECT.

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nell'editor di query, inserisci la seguente istruzione:

    SELECT
      capacity_commitment_id
    FROM
      `region-LOCATION`.INFORMATION_SCHEMA.CAPACITY_COMMITMENTS_BY_PROJECT
    WHERE
      project_id = 'ADMIN_PROJECT_ID'
      AND slot_count = 100;

    Sostituisci quanto segue:

  3. Fai clic su Esegui.

Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.

bq

Utilizza il comando bq ls con il flag --capacity_commitment per elencare gli impegni per un progetto di amministrazione.

bq ls \
    --capacity_commitment=true \
    --location=LOCATION \
    --project_id=ADMIN_PROJECT_ID

Sostituisci quanto segue:

Aggiornamento impegni relativi alla capacità

Puoi apportare i seguenti aggiornamenti a un impegno di capacità:

  • Rinnova un impegno esistente.
  • Convertire un impegno in un piano di impegno con una durata più lunga.
  • Suddividi un impegno in due impegni.
  • Unire due impegni in un unico impegno.

Autorizzazioni obbligatorie

Per aggiornare gli impegni di capacità, devi disporre della seguente autorizzazione IAM (Identity and Access Management):

Ognuno dei seguenti ruoli IAM predefiniti include questa autorizzazione:

  • BigQuery Admin
  • BigQuery Resource Admin

Per saperne di più sui ruoli IAM in BigQuery, consulta Ruoli e autorizzazioni predefiniti.

Rinnova un impegno

Gli impegni annuali hanno un piano di rinnovo, che specifichi quando crei o converti un impegno annuale. Puoi modificare il piano di rinnovo dell'impegno annuale in qualsiasi momento prima della data di fine dell'impegno.

Console

Puoi modificare il piano di rinnovo per un impegno annuale nel seguente modo:

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic sulla scheda Impegni slot.

  4. Trova l'impegno che vuoi modificare.

  5. Fai clic su Azioni e poi seleziona l'opzione Modifica piano di rinnovo.

  6. Seleziona il nuovo piano di rinnovo.

bq

Per modificare la scelta del piano di rinnovo per un impegno annuale, utilizza il comando bq update con il flag --capacity_commitment e il flag --renewal_plan.

bq update \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --renewal_plan=PLAN_TYPE \
    --capacity_commitment=true \
    COMMITMENT_ID

Sostituisci quanto segue:

Convertire un impegno in una durata più lunga

Puoi scegliere di convertire il tuo impegno in un tipo di impegno di durata maggiore in qualsiasi momento:

  • Puoi convertire il tuo impegno per gli slot flessibili in un impegno mensile o annuale.
  • Puoi convertire il tuo impegno mensile in un impegno annuale.

Non appena aggiorni l'impegno, ti viene addebitata la tariffa associata al nuovo piano e la data di fine viene reimpostata.

Per convertire un impegno, utilizza il comando bq update con il flag --plan.

bq update \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --plan=PLAN_TYPE \
    --renewal_plan=RENEWAL_PLAN \
    --capacity_commitment=true \
    COMMITMENT_ID

Sostituisci quanto segue:

  • ADMIN_PROJECT_ID: l'ID progetto
  • LOCATION: la posizione dell'impegno
  • PLAN_TYPE: il tipo di piano, ad esempio FLEX, MONTHLY o ANNUAL.
  • RENEWAL_PLAN: il piano di rinnovo

    Questo vale solo se PLAN_TYPE è ANNUAL. Se PLAN_TYPE è MONTHLY, ometti questo flag.

  • COMMITMENT_ID: l'ID dell'impegno

    Per ottenere l'ID, vedi Visualizzare gli impegni acquistati.

Suddividere un impegno

Puoi dividere l'impegno in due impegni. Questa opzione può essere utile se vuoi rinnovare parte di un impegno. Ad esempio, se hai un impegno annuale di 1000 slot, puoi separare 300 slot in un nuovo impegno, lasciando 700 slot nell'impegno originale. Potresti quindi rinnovare 700 slot alla tariffa annuale e convertire 300 slot in slot flessibili dopo la data di fine.

Quando dividi un impegno, il nuovo impegno ha lo stesso piano e la stessa data di fine dell'impegno originale.

Console

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic sulla scheda Impegni slot.

  4. Seleziona l'impegno che vuoi dividere.

  5. Fai clic su Dividi.

  6. Nella pagina Suddividi impegno, utilizza il cursore Configura suddivisione per selezionare il numero di slot da inserire in ogni suddivisione, con incrementi di 100 slot.

  7. Fai clic su Dividi per dividere l'impegno. Il nuovo impegno è elencato nella scheda Impegni di slot.

bq

Per dividere gli impegni, utilizza il comando bq update.

bq update \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --split \
    --slots=SLOTS_TO_SPLIT \
    --capacity_commitment=true \
    COMMITMENT_ID

Sostituisci quanto segue:

  • ADMIN_PROJECT_ID: l'ID progetto
  • LOCATION: la posizione dell'impegno
  • SLOTS_TO_SPLIT: il numero di slot da dividere dall'impegno originale in un nuovo impegno
  • COMMITMENT_ID: l'ID dell'impegno

    Per ottenere l'ID, vedi Visualizzare gli impegni acquistati.

Unire due impegni

Puoi unire più impegni in un unico impegno. Gli impegni da unire devono essere tutti dello stesso tipo (FLEX, MONTHLY, ANNUAL o THREE_YEAR). La data di fine dell'impegno combinato è la data di fine massima degli impegni originali. Se uno degli impegni ha una data di fine precedente, viene esteso fino alla data successiva e ti viene addebitato un importo proporzionale per questi slot.

Console

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic sulla scheda Impegni slot.

  4. Seleziona gli impegni che vuoi unire.

  5. Fai clic su Unisci.

  6. Nella pagina Unisci impegni, esamina i dettagli dell'unione e fai clic su Unisci. Il nuovo impegno combinato è elencato nella scheda Impegni di slot.

bq

Per unire due impegni in un unico impegno, utilizza il comando bq update:

bq update \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --merge=true \
    --capacity_commitment=true \
    COMMITMENT1,COMMITMENT2

Sostituisci quanto segue:

  • ADMIN_PROJECT_ID: l'ID progetto
  • LOCATION: la posizione degli impegni
  • COMMITMENT1: il primo impegno da unire
  • COMMITMENT2: il secondo impegno da unire

Elimina un impegno

Puoi eliminare un impegno per la capacità se la data di fine è nel passato. La data di fine dell'impegno viene visualizzata nella console Google Cloud . Prima di eliminare un impegno, assicurati che ci siano slot non allocati sufficienti. In caso contrario, devi diminuire il numero di slot in una prenotazione o rimuovere completamente le prenotazioni.

Autorizzazioni obbligatorie

Per eliminare i commitment di capacità, devi disporre della seguente autorizzazione IAM (Identity and Access Management):

Ognuno dei seguenti ruoli IAM predefiniti include questa autorizzazione:

  • BigQuery Admin
  • BigQuery Resource Admin

Per saperne di più sui ruoli IAM in BigQuery, consulta Ruoli e autorizzazioni predefiniti.

Eliminazione di un impegno di capacità

Console

Per eliminare un impegno di capacità, completa i seguenti passaggi:

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nel menu di navigazione, fai clic su Gestione della capacità.

  3. Fai clic sulla scheda Impegni slot.

  4. Nell'elenco a discesa Località, seleziona la località appropriata.

  5. Trova l'impegno che vuoi eliminare.

  6. Espandi l'opzione Azioni.

  7. Fai clic su Elimina.

  8. Digita "RIMUOVI" e fai clic su Procedi.

SQL

Per eliminare un impegno di capacità, utilizza l'istruzione DDL DROP CAPACITY.

  1. Nella console Google Cloud , vai alla pagina BigQuery.

    Vai a BigQuery

  2. Nell'editor di query, inserisci la seguente istruzione:

    DROP CAPACITY
      `ADMIN_PROJECT_ID.region-LOCATION.COMMITMENT_ID`;

    Sostituisci quanto segue:

  3. Fai clic su Esegui.

Per maggiori informazioni su come eseguire le query, consulta Eseguire una query interattiva.

bq

Per eliminare un impegno di capacità, utilizza il comando bq rm con il flag --capacity_commitment:

bq rm \
    --project_id=ADMIN_PROJECT_ID \
    --location=LOCATION \
    --capacity_commitment=true \
    COMMITMENT_ID

Sostituisci quanto segue:

Risoluzione dei problemi relativi agli impegni di capacità

Questa sezione descrive i passaggi per la risoluzione dei problemi che potrebbero esserti utili in caso di problemi con l'utilizzo di BigQuery Reservations.

Gli slot acquistati sono in attesa

Gli slot sono soggetti alla capacità disponibile. Quando acquisti impegni slot e BigQuery li alloca, la colonna Stato mostra un segno di spunta. Se BigQuery non riesce ad allocare subito gli slot richiesti, la colonna Stato rimane in attesa. Potresti dover attendere diverse ore prima che gli slot diventino disponibili. Se hai bisogno di accedere prima agli slot, prova a seguire questi passaggi:

  1. Elimina l'impegno in attesa.
  2. Acquista un nuovo impegno per un numero inferiore di slot. A seconda della capacità, l'impegno più piccolo potrebbe attivarsi immediatamente.
  3. Acquista gli slot rimanenti come impegno separato. Questi slot potrebbero essere visualizzati come in attesa nella colonna Stato, ma in genere vengono attivati entro poche ore.
  4. (Facoltativo) Quando entrambi gli impegni sono disponibili, puoi unirli in un unico impegno, a condizione che tu abbia acquistato lo stesso piano per entrambi.

Se un impegno di slot non va a buon fine o richiede molto tempo per essere completato, valuta la possibilità di utilizzare temporaneamente i prezzi on demand. Con questa soluzione, potresti dover eseguire query critiche su un progetto diverso non assegnato ad alcuna prenotazione oppure potresti dover rimuovere completamente l'assegnazione del progetto.