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
-
Install the Google Cloud CLI, then initialize it by running the following command:
gcloud init
- Set a default region and zone.
Arresta la VM.
gcloud compute instances stop VM_NAME
Sostituisci
VM_NAME
con il nome della VM da arrestare.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 specificoNODE_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.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à.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 arrestareZona
ZONE
contenente il progettoVM_NAME
nome della VM da arrestare
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 VMZONE
zona contenente il progettoVM_NAME
nome della VM da spostare in un gruppo di nodi specificoNODE_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
.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 avviareZONE
zona contenente il progettoVM_NAME
nome della VM da avviare
Arresta la VM.
gcloud compute instances stop VM_NAME
Sostituisci
VM_NAME
con il nome della VM da arrestare.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à.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.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 arrestareZONE
zona contenente il progettoVM_NAME
nome della VM da arrestare
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 spostareZona
ZONE
contenente il progettoNome
VM_NAME
della VM da cui cancellare affinità dei nodi
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 avviareZONE
zona contenente il progettoVM_NAME
nome della VM da avviare
- Prima di spostare le VM sui nodi single-tenant, scopri di più sul nodo single-tenant prezzi.
- Leggi Bring Your Own License.
- Leggi le Domande frequenti sulle licenze Microsoft.
- Scopri come portare immagini con licenze esistenti su Google Cloud.
- Scopri come scalare automaticamente il nodo single-tenant gruppi di lavoro.
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
REST
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
REST
Passaggi successivi
Salvo quando diversamente specificato, i contenuti di questa pagina sono concessi in base alla licenza Creative Commons Attribution 4.0, mentre gli esempi di codice sono concessi in base alla licenza Apache 2.0. Per ulteriori dettagli, consulta le norme del sito di Google Developers. Java è un marchio registrato di Oracle e/o delle sue consociate.
Ultimo aggiornamento 2024-10-14 UTC.
-