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. Su multi-tenant host, le VM in genere condividono le risorse host con le VM di altri progetti clienti. Quando sposti una VM su un nodo single-tenant, il tuo progetto ha accesso esclusivo e controllo completo dell'hardware dei nodi single-tenant. 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à del nodo, 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 single-tenant o nodo

Spostamento temporaneo di carichi di lavoro in single-tenancy

A causa della fluttuazione dei requisiti dei carichi di lavoro, ad esempio delle esigenze periodiche di isolamento aggiuntivo per esaminare le prestazioni o modifiche alla conformità potresti dover spostare temporaneamente carichi di lavoro specifici sui nodi single-tenant. Quando non hai più bisogno della single-tenancy, esegui nuovamente il deployment delle VM 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 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 single-tenancy della VM viene specificata utilizzando l'affinità affinità personalizzata anti-affinità etichette, la VM potrebbe riavviarsi 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 come segue.

    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 ulteriori informazioni, vedi Esegui l'autenticazione per l'utilizzo di REST nella documentazione sull'autenticazione di Google Cloud.

Spostamento di una VM in single-tenancy

Aggiorna la proprietà spostando la VM su 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 una gruppo di nodi specifico

    • NODE_GROUP_NAME del nome del gruppo di nodi in trasferire 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 gcloud compute instances set-scheduling un comando kubectl.

  3. Avviare 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 in 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 dell'ID del progetto contenente per trasferire la VM

    • ZONE zona contenente il progetto

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

    • NODE_GROUP_NAME del nome del gruppo di nodi in trasferire la VM

    In alternativa, puoi spostare una VM su un nodo single-tenant utilizzando il nome del nodo o usando un'etichetta di affinità. Per ulteriori informazioni, consulta il metodo instances.setScheduling.

  3. Avvia la VM. Per ulteriori informazioni su questo comando, vedi 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

    • ZONE zona contenente il progetto

    • VM_NAME nome della VM da avviare

Spostamento di 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 in modo da poterlo 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 da cui rimuovere il nodo affinità.

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

    gcloud compute instances start VM_NAME
    

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

REST

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

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

    Sostituisci quanto segue:

    • ID PROJECT_ID del progetto contenente VM da arrestare

    • ZONE zona contenente il progetto

    • VM_NAME nome della VM da arrestare

  2. Cancella le affinità dei nodi dalla VM per spostarlo 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

    • Nome VM_NAME della VM da cui cancellare 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

    • ZONE zona contenente il progetto

    • VM_NAME nome della VM da avviare

Passaggi successivi