Aggiornamento della tenancy VM


Questa pagina descrive come aggiornare la tenancy di una VM modificando le etichette di affinità dei nodi della VM.

Per impostazione predefinita, Compute Engine esegue il deployment delle VM su host multi-tenant. Negli host multi-tenant, le VM in genere condividono le risorse dell'host con le VM di altri progetti e clienti. Quando sposti una VM in un nodo monoproprietario, il tuo progetto ha accesso esclusivo e controllo completo sull'hardware del nodo monoproprietario. Sei l'unico tenant su quel nodo, quindi i tuoi carichi di lavoro sono isolati da quelli di altri progetti e delle relative VM.

Modificando le etichette di affinità dei nodi, puoi spostare una VM nei seguenti modi:

  • Da un host multi-tenant a un gruppo di nodi o a un nodo single-tenant
  • Da un gruppo di nodi o da un nodo single-tenant a un host multi-tenant
  • Da un nodo single-tenant a un altro nodo o gruppo di nodi single-tenant
  • Da un gruppo di nodi single-tenant a un altro gruppo di nodi o a un altro nodo single-tenant

Spostare temporaneamente i carichi di lavoro in modalità single-tenancy

A causa della variabilità dei requisiti dei carichi di lavoro, ad esempio la necessità periodica di un isolamento aggiuntivo per esaminare le prestazioni o le modifiche ai regolamenti di conformità, potrebbe essere necessario spostare temporaneamente carichi di lavoro specifici su nodi single-tenant. Quando non avrai più bisogno del modello single-tenant, esegui nuovamente il deployment delle VM su un host multi-tenant. Quando modifichi la tenancy di una VM, Compute Engine conserva le configurazioni della VM.

Ribilanciamento dei carichi di lavoro single-tenant

Oltre a spostare le VM da e verso nodi e gruppi di nodi di proprietà esclusiva, puoi spostarle tra nodi e gruppi di nodi, il che può aiutarti a consolidare i nodi e a riequilibrare i carichi di lavoro. Il trasferimento di una VM richiede un riavvio, quindi pianifica il trasferimento delle VM in base ai requisiti di disponibilità dei tuoi carichi di lavoro.

Limitazioni

  • Quando sposti una VM già in esecuzione su un nodo single-tenant, la VM potrebbe riavviarsi su un altro nodo. Se la proprietà esclusiva di una VM è specificata dal nome del gruppo di nodi o utilizzando l'node-group-name etichetta di affinità predefinita, la VM può essere riavviata su qualsiasi nodo del gruppo di nodi. Se la proprietà esclusiva della VM è specificata utilizzando etichette di affinità personalizzate di affinità o anti-affinità, la VM potrebbe riavviarsi su qualsiasi nodo di qualsiasi gruppo di nodi nella zona.

Prima di iniziare

  • Se non l'hai ancora fatto, configura l'autenticazione. L'autenticazione è la procedura mediante la quale la tua identità viene verificata per l'accesso alle API e ai servizi Google Cloud. Per eseguire codice o esempi da un ambiente di sviluppo locale, puoi autenticarti su Compute Engine selezionando una delle seguenti opzioni:

    Select the tab for how you plan to use the samples on this page:

    gcloud

    1. Install the Google Cloud CLI, then initialize it by running the following command:

      gcloud init
    2. Set a default region and zone.
    3. REST

      Per utilizzare gli esempi dell'API REST in questa pagina in un ambiente di sviluppo locale, utilizza le credenziali fornite a gcloud CLI.

        Install the Google Cloud CLI, then initialize it by running the following command:

        gcloud init

      Per saperne di più, consulta Eseguire l'autenticazione per l'utilizzo di REST nella documentazione sull'autenticazione di Google Cloud.

Spostare una VM in modalità single-tenancy

Aggiorna la proprietà spostando la VM in un nodo o un gruppo di nodi single-tenant specifico da un altro nodo o gruppo di nodi o da un host multi-tenant.

gcloud

  1. Arresta la VM.

    gcloud compute instances stop VM_NAME
    

    Sostituisci VM_NAME con il nome della VM da arrestare.

  2. Aggiorna la tenancy specificando il gruppo di nodi a cui spostare la VM.

    gcloud compute instances set-scheduling VM_NAME \
        --node-group=NODE_GROUP_NAME
    

    Sostituisci quanto segue:

    • VM_NAME nome della VM da spostare in un gruppo di nodi specifico

    • NODE_GROUP_NAME nome del gruppo di nodi in cui spostare la VM

    In alternativa, puoi spostare una VM in un nodo monoproprietario utilizzando il nome del nodo o un'etichetta di affinità. Per ulteriori informazioni, consulta il gcloud compute instances set-scheduling comando.

  3. Avvia la VM.

    gcloud compute instances start VM_NAME
    

    Sostituisci VM_NAME con il nome della VM da avviare nel gruppo di nodi specificato in precedenza dai contenuti di un file di etichette di affinità.

REST

  1. Arresta la VM. Per ulteriori informazioni su questo comando, consulta instances.stop.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/stop
    

    Sostituisci quanto segue:

    • PROJECT_ID: ID del progetto contenente la VM da arrestare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da arrestare

  2. Aggiorna la tenancy specificando il gruppo di nodi a cui spostare la VM.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/setScheduling
    
    {
      "nodeAffinities": [
        {
          "key": "compute.googleapis.com/node-group-name",
          "operator": "IN",
          "values": [
            "NODE_GROUP_NAME"
          ]
        }
      ]
    }
    

    Sostituisci quanto segue:

    • PROJECT_ID ID del progetto contenente la VM da spostare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da spostare in un gruppo di nodi specifico

    • NODE_GROUP_NAME nome del gruppo di nodi in cui spostare la VM

    In alternativa, puoi spostare una VM in un nodo monoproprietario utilizzando il nome del nodo o un'etichetta di affinità. Per ulteriori informazioni, consulta il metodo instances.setScheduling.

  3. Avvia la VM. Per ulteriori informazioni su questo comando, consulta instances.start.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/start
    

    Sostituisci quanto segue:

    • PROJECT_ID ID del progetto contenente la VM da avviare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da avviare

Rimuovere una VM dalla modalità single-tenancy

Se la VM non richiede più hardware dedicato, ad esempio dopo un evento che ha richiesto l'isolamento della VM dalle altre VM, spostala da un nodo single-tenant a un host multi-tenant.

gcloud

  1. Arresta la VM.

    gcloud compute instances stop VM_NAME
    

    Sostituisci VM_NAME con il nome della VM da arrestare.

  2. Cancella le affinità dei nodi dalla VM per poterla spostare in un host multi-tenant.

    gcloud compute instances set-scheduling VM_NAME --clear-node-affinities
    

    Sostituisci VM_NAME con il nome della VM per la quale rimuovere le affinità dei nodi.

  3. Avvia la VM su un host multi-tenant.

    gcloud compute instances start VM_NAME
    

    Sostituisci VM_NAME con il nome della VM da cui hai cancellato in precedenza le affinità dei nodi.

REST

  1. Arresta la VM. Per ulteriori informazioni su questo comando, consulta instances.stop.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/stop
    

    Sostituisci quanto segue:

    • PROJECT_ID ID del progetto contenente la VM da arrestare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da arrestare

  2. Cancella le affinità dei nodi dalla VM per spostarla in un host multi-tenant.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/setScheduling
    
    {
      "nodeAffinities": []
    }
    

    Sostituisci quanto segue:

    • PROJECT_ID ID del progetto contenente la VM da spostare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da cui eliminare le affinità dei nodi

  3. Avvia la VM su un host multi-tenant. Per ulteriori informazioni su questo comando, consulta instances.start.

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_ID/zones/ZONE/instances/VM_NAME/start
    

    Sostituisci quanto segue:

    • PROJECT_ID ID del progetto contenente la VM da avviare

    • Zona ZONE contenente il progetto

    • VM_NAME nome della VM da avviare

Passaggi successivi