Déplacer une instance de VM entre plusieurs zones ou régions


Ce document explique comment déplacer une instance de machine virtuelle (VM) entre des zones ou des régions.

Avant de commencer

Exigences

Cette section répertorie les exigences pour déplacer une VM entre des zones et des régions :

  • Quota du projet. Votre projet doit disposer d'un quota suffisant pour effectuer les opérations suivantes :

    • Créer des instantanés.
    • Convertir les adresses IP externes éphémères.
    • Créer des VM et des disques dans la région de destination.

      Par exemple, si la VM que vous souhaitez déplacer est associée à trois disques, vous devez disposer d'un quota suffisant pour pouvoir créer trois instantanés de disque persistant temporaires et trois disques. Après avoir créé vos disques, vous pouvez supprimer vos instantanés temporaires.

    Consultez la page Quotas pour vous assurer que vous disposez d'un quota suffisant pour les ressources précédentes. Pour en savoir plus, consultez la page Comprendre les quotas.

  • Disques persistants. Les disques persistants associés à la VM que vous souhaitez déplacer ne sont pas associés à d'autres VM.

  • Disques SSD locaux. Les disques SSD locaux sont destinés au stockage temporaire. Les données stockées sur ces disques ne sont pas conservées lorsque vous arrêtez manuellement une VM. Si vous devez conserver les données présentes sur des disques SSD locaux, répliquez-les à l'aide d'une option de stockage durable (telle que des disques persistants).

  • GPU. Si votre VM comprend des GPU, vérifiez que ceux que vous souhaitez utiliser sont disponibles dans la zone de destination de la VM. Pour obtenir la liste des GPU et des zones dans lesquelles ils sont disponibles, consultez la section GPU sur Compute Engine.

  • Sous-réseau. Si vous souhaitez déplacer votre VM entre des régions (par exemple, entre us-west1-a et asia-south1-b) et que votre VM appartient à un sous-réseau, vous devez sélectionner un nouveau sous-réseau pour votre VM. Pour obtenir des instructions sur la création de sous-réseaux, consultez la section Ajouter des sous-réseaux.

Vous pouvez déplacer une VM même si l'un des scénarios suivants s'applique :

  • L'instance de VM est à l'état TERMINATED.
  • L'instance de VM est une VM protégée qui utilise le micrologiciel UEFI.

Limite

Si vous déplacez une VM d'une région à une autre, vous ne pouvez pas conserver son adresse IP interne ou externe éphémère. Vous devez choisir une nouvelle adresse IP lors de la recréation de la VM.

Propriétés de la ressource

Pour déplacer votre VM, vous devez l'arrêter, la déplacer vers la zone ou la région de destination, puis la redémarrer. Après avoir déplacé votre VM, mettez à jour les références à votre ressource d'origine, telles que les VM ou les pools cibles qui pointent vers la VM précédente.

Pendant le déplacement, certaines propriétés générées par le serveur associées à votre VM et à vos disques changent.

Propriétés modifiées pour les VM

Le tableau suivant décrit les propriétés qui changent pour les VM :

Nom de propriété Modifications
Adresse IP interne Une nouvelle adresse IP interne est généralement attribuée, mais il est possible que la VM conserve son adresse IP interne d'origine.
Adresse IP externe Si vous déplacez la VM entre plusieurs zones au sein de la même région, l'adresse IP externe reste la même. Dans le cas contraire, choisissez une adresse IP différente pour l'instance de VM.
Plate-forme du processeur Selon la plate-forme de processeur disponible dans votre zone de destination, votre VM peut disposer d'une plate-forme différente après son déplacement. Pour obtenir la liste complète des plates-formes de processeur disponibles dans chaque zone, consultez la section Régions et zones disponibles.
Réseau/Sous-réseau Si votre VM appartient à un sous-réseau et que vous la déplacez vers une autre région, vous devez choisir un nouveau sous-réseau pour votre VM. Si vous déplacez une VM vers une zone de la même région, celle-ci conserve son sous-réseau.

Propriétés modifiées pour les disques

Le tableau suivant décrit les propriétés modifiées pour les disques :

Nom de propriété Modifications
Instantané source L'instantané source du nouveau disque est remplacé par l'instantané temporaire créé pendant le déplacement.
ID de l'instantané source L'ID de l'instantané source est remplacé par l'ID de l'instantané temporaire.
Image source Le champ d'image source est vide.
ID de l'image L'ID de l'image est vide.
Dernier horodatage de dissociation Le dernier horodatage de dissociation est vide.
Dernier horodatage d'association Le dernier horodatage d'association est défini sur l'horodatage lié à l'association du nouveau disque à la nouvelle instance.

Propriétés modifiées pour les VM et les disques

Le tableau suivant décrit les propriétés modifiées pour les VM et les disques :

Nom de propriété Modifications
ID Un nouvel ID de ressource est généré.
Horodatage de création Un nouvel horodatage de création est généré.
URL des ressources de la zone Toutes les URL des ressources de la zone sont modifiées pour correspondre à la zone de destination. La liste suivante indique les URL de ressources modifiées :
  • L'URL du disque source d'une VM
  • L'URL du type de machine d'une VM
  • Les URL des liens auto
  • Les URL de zone
  • Les URL de type de disque
  • Toutes les URL des VM répertoriées dans la liste users[] d'un disque

Déplacer une VM

Pour déplacer une VM d'une zone ou d'une région à une autre, procédez comme suit :

  1. Créez une image système de votre VM source.
  2. Créez une VM à partir de l'image système dans une zone ou une région différente.

L'exemple suivant explique comment déplacer une VM. Dans cet exemple, vous déplacez une VM nommée myinstance qui comporte deux disques persistants nommés mybootdisk et mydatadisk, de europe-west1-c à us-west1-b.

La VM source possède les propriétés suivantes :

gcloud compute instances list
NAME       ZONE           MACHINE_TYPE  INTERNAL_IP    EXTERNAL_IP     STATUS
myinstance europe-west1-c n1-standard-4 10.240.116.177 146.148.112.106 RUNNING

Pour déplacer la VM dans une autre zone :

  1. Identifiez les disques associés à VM que vous souhaitez déplacer.

    Accéder à la page Disques

    Dans cet exemple, les deux disques suivants sont associés à la VM myinstance :

    • Un disque de démarrage appelé mybootdisk
    • Un disque de données appelé mydatadisk
  2. Définissez l'état de suppression automatique de mybootdisk et de mydatadisk sur false, pour vous assurer de conserver les disques lors de la suppression de la VM.

    gcloud compute instances set-disk-auto-delete myinstance --zone europe-west1-c \
        --disk mybootdisk --no-auto-delete
    

    Si l'état de suppression automatique a bien été mis à jour, gcloud compute renvoie la réponse Updated [...]. S'il était déjà défini sur "false", gcloud compute renvoie la réponse suivante :

    No change requested; skipping update for [myinstance].
  3. (Facultatif) Enregistrez vos métadonnées de VM.

    Lorsque vous supprimez votre VM, les métadonnées de la VM sont également effacées. Vous pouvez sauvegarder ces informations dans un fichier distinct, puis réutiliser les métadonnées dans la nouvelle VM.

    Décrivez les métadonnées de votre VM en exécutant la commande suivante :

    gcloud compute instances describe myinstance --zone europe-west1-c
    

    Enregistrez le contenu dans un fichier séparé.

  4. Créez des sauvegardes de vos données.

    Par précaution, sauvegardez vos données pendant que les disques persistants sont associés à la VM, en utilisant des instantanés de disque persistant. Avant de prendre un instantané, assurez-vous qu'il est cohérent avec l'état du disque persistant en respectant les bonnes pratiques concernant les instantanés.

    Après avoir effacé les tampons de votre disque, créez les instantanés :

    gcloud compute disks snapshot mybootdisk mydatadisk \
        --snapshot-names backup-mybootsnapshot,backup-mydatasnapshot \
        --zone europe-west1-c
    

    Pour vérifier que l'instantané a bien été créé, exécutez la commande gcloud compute snapshots list.

  5. (Facultatif) Si vous déplacez une VM entre des zones de la même région et que vous souhaitez conserver son adresse IP interne ou externe éphémère, convertissez l'instance interne ou une adresse IP externe vers une adresse IP statique que vous pouvez réutiliser ultérieurement.

  6. Supprimez votre VM.

    La suppression de votre VM l'arrête correctement et dissocie tous les disques persistants.

    gcloud compute instances delete myinstance --zone europe-west1-c
    

    gcloud vous invite à confirmer la suppression :

     The following VMs are deleted. Any attached disks configured to
     be auto-deleted are deleted unless they are attached to any other
     VMs or the --keep-disks flag is given and specifies them for keeping.
     Deleting a disk is irreversible and any data on the disk is lost.
      — [myinstance] in [europe-west1-c]
     

    Do you want to continue (Y/n)?

    Comme vous avez précédemment désactivé l'état de suppression automatique des disques, appuyez sur Y pour ignorer l'avertissement et continuer.

  7. Créez ensuite un autre instantané du disque de démarrage et du disque de données.

    gcloud compute disks snapshot mybootdisk mydatadisk \
        --snapshot-names mybootsnapshot,mydatasnapshot \
        --zone europe-west1-c
    
    Created [.../mydatasnapshot].
    Created [.../mybootsnapshot].
  8. (Facultatif) Supprimez vos disques persistants.

    Si vous prévoyez de réutiliser les noms des disques persistants pour les nouveaux disques, vous devez supprimer les disques existants afin de libérer les noms. Cette suppression permet également de réduire les coûts de stockage sur disque persistant.

    Si vous n'envisagez pas de réutiliser les mêmes noms de disques, il n'est pas nécessaire de les supprimer.

    gcloud compute disks delete mybootdisk mydatadisk --zone europe-west1-c
    
  9. Créez des disques persistants dans us-west1-b à partir des instantanés que vous avez créés. Commencez par créer le disque de démarrage.

    gcloud compute disks create mybootdiskb --source-snapshot mybootsnapshot \
        --zone us-west1-b
    
    Created [.../mybootdiskb].
    NAME        ZONE           SIZE_GB TYPE        STATUS
    mybootdiskb us-west1-b     100     pd-standard READY

    Créez ensuite le disque de données.

    gcloud compute disks create mydatadiskb --source-snapshot mydatasnapshot \
        --zone us-west1-b
    
    Created [.../mydatadiskb].
    NAME        ZONE           SIZE_GB TYPE        STATUS
    mydatadiskb us-west1-b 4000    pd-standard READY
  10. Recréez votre VM dans us-west1-b.

    • Si vous avez choisi d'enregistrer vos métadonnées de VM dans un fichier (par exemple, myinstance.describe), vous pouvez l'exploiter pour définir les mêmes métadonnées sur votre VM.

    • Si votre VM possédait une adresse IP externe statique, vous pouvez la réattribuer à votre nouvelle VM en spécifiant l'option --address [ADDRESS]. Si vous déplacez une VM d'une région à une autre, vous devez choisir une adresse IP externe différente pour la nouvelle instance de VM.

    • Si votre VM possédait une adresse IP interne statique, vous pouvez la réattribuer à votre nouvelle VM en spécifiant l'option --private-network-ip ADDRESS. Si vous déplacez une VM d'une région à une autre, vous devez choisir une adresse IP interne différente pour la nouvelle instance de VM.

    • Si votre VM incluait des GPU, ajoutez des GPU à la VM à l'aide de l'option --accelerator.

    • Si la VM utilise un sous-réseau spécifique, ajoutez l'option --subnet [SUBNET_NAME].

    Pour obtenir la liste complète des indicateurs supplémentaires, consultez la page concernant gcloud compute instances create.

    gcloud compute instances create myinstanceb --machine-type n1-standard-4 \
        --zone us-west1-b \
        --disk name=mybootdiskb,boot=yes,mode=rw \
        --disk name=mydatadiskb,mode=rw
    
    Created [.../myinstanceb].
    NAME        ZONE           MACHINE_TYPE  INTERNAL_IP    EXTERNAL_IP     STATUS
    myinstanceb us-west1-b     n1-standard-4 10.240.173.229 146.148.112.106 RUNNING
  11. (Facultatif) Supprimez vos instantanés de disque persistant.

    Après avoir confirmé le déplacement de vos machines virtuelles, supprimez les instantanés temporaires que vous avez créés afin de réduire les coûts de stockage.

    gcloud compute snapshots delete mybootsnapshot mydatasnapshot
    

    Si vous n'avez plus besoin de vos instantanés de sauvegarde, supprimez-les également :

    gcloud compute snapshots delete backup-mybootsnapshot backup-mydatasnapshot
    

Étapes suivantes