Crea uno snapshot del disco coerente con l'applicazione Windows


In Compute Engine, puoi utilizzare gli snapshot per eseguire il backup dei dati del disco. Poiché gli snapshot sono incrementali, puoi crearli con prestazioni più elevate e costi di archiviazione totali inferiori rispetto alla creazione di immagini del disco complete.

Gli snapshot coerenti con l'applicazione acquisiscono lo stato dei dati dell'applicazione al momento del backup con tutte le transazioni dell'applicazione completate e tutte le scritture in attesa scaricate sul disco. Sulle VM Windows, utilizzi il servizio Volume Shadow Copy (VSS) per creare snapshot coerenti con l'applicazione senza prima arrestare l'istanza o scollegare il disco dalla VM.

Prima di iniziare

  • Crea un'istanza Windows.
  • Consulta le best practice per la creazione di snapshot.
  • Se non l'hai ancora fatto, configura l'autenticazione. L'autenticazione è il processo mediante il quale la tua identità viene verificata per l'accesso ai Google Cloud servizi e alle API. 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:

    Console

    When you use the Google Cloud console to access Google Cloud services and APIs, you don't need to set up authentication.

    gcloud

      1. After installing the Google Cloud CLI, initialize it by running the following command:

        gcloud init

        If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.

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

        Per utilizzare gli esempi di API REST in questa pagina in un ambiente di sviluppo locale, utilizzi le credenziali che fornisci a gcloud CLI.

          After installing the Google Cloud CLI, initialize it by running the following command:

          gcloud init

          If you're using an external identity provider (IdP), you must first sign in to the gcloud CLI with your federated identity.

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

Limitazioni

Gli snapshot del disco su Windows presentano le seguenti limitazioni:

  • Gli snapshot VSS funzionano solo su istanze Windows con la versione dell'immagine v20160810 e successive. Per le istanze con immagini precedenti, crea uno snapshot senza utilizzare VSS.
  • Il disco collegato deve utilizzare un file system NTFS, exFAT o ReFS.
  • Gli snapshot VSS aiutano a conservare i dati solo se esegui applicazioni compatibili con VSS in grado di coordinarsi per creare un backup coerente dei dati.
  • Se l'operazione di snapshot VSS non viene completata entro 300 secondi, lo snapshot non va a buon fine e viene visualizzato un errore di timeout.

Crea uno snapshot VSS di Windows

Puoi creare snapshot del servizio VSS (Volume Shadow Copy Service) senza dover arrestare l'istanza o scollegare il disco dalla VM. Gli snapshot VSS sono destinati a scopi di backup e ripristino su sistemi con app compatibili con VSS.

Gli snapshot VSS hanno lo stesso prezzo degli snapshot normali di Persistent Disk o Hyperdisk e vengono addebitati solo per la dimensione totale dello snapshot.

Crea lo snapshot

Console

  1. Vai alla pagina Crea uno snapshot nella console Google Cloud .

    Vai alla pagina Crea uno snapshot
  2. Inserisci un nome per lo snapshot.
  3. Seleziona un tipo di snapshot. Il valore predefinito è uno snapshot STANDARD, che è l'opzione migliore per il backup a lungo termine e ripristino di emergenza.

    Scegli Snapshot di archiviazione per una conservazione dei dati più conveniente.

  4. (Facoltativo) Inserisci una Descrizione dello snapshot.
  5. In Disco di origine, seleziona il disco esistente di cui vuoi creare uno snapshot.
  6. Nella sezione Località, scegli la località di archiviazione degli snapshot.

    La località predefinita o personalizzata indicata nelle impostazioni degli snapshot viene selezionata automaticamente. Se vuoi, puoi ignorare le impostazioni e archiviare gli snapshot in una località di archiviazione personalizzata nel seguente modo:

    1. Scegli il tipo di località di archiviazione che preferisci per lo snapshot.

      • Scegli Più regioni per una maggiore disponibilità a un costo superiore.
      • Scegli snapshot regionali per un maggiore controllo sulla posizione fisica dei dati a un costo inferiore.
    2. Nel campo Seleziona località, seleziona la regione specifica o più regioni che vuoi utilizzare. Per utilizzare la regione o più regioni più vicine al tuo disco di origine, seleziona In base alla località del disco.
  7. Seleziona l'opzione Abilita snapshot coerente con l'applicazione.
  8. Fai clic su Crea per creare lo snapshot.

gcloud

Per creare uno snapshot VSS, utilizza il comando gcloud compute snapshots create e includi il flag --guest-flush.

Puoi creare lo snapshot nella policy di posizione di archiviazione definita dalle impostazioni degli snapshot o utilizzando una posizione di archiviazione alternativa a tua scelta. Per saperne di più, vedi Scegliere la località di archiviazione degli snapshot.

  • Per creare uno snapshot nella posizione predefinita personalizzata o predefinita indicata nelle impostazioni degli snapshot, utilizza il comando gcloud compute snapshots create.

    gcloud compute snapshots create SNAPSHOT_NAME \
        --source-disk-zone=SOURCE_ZONE \
        --source-disk=SOURCE_DISK_NAME \
        --snapshot-type=SNAPSHOT_TYPE \
        --guest-flush
    
  • In alternativa, per ignorare le impostazioni degli snapshot e creare uno snapshot in una posizione di archiviazione personalizzata, includi il flag --storage-location per indicare dove archiviare lo snapshot.

    gcloud compute snapshots create SNAPSHOT_NAME \
        --source-disk-zone=SOURCE_ZONE \
        --source-disk=SOURCE_DISK_NAME \
        --snapshot-type=SNAPSHOT_TYPE \
        --storage-location=STORAGE_LOCATION \
        --guest-flush
    
  • (Anteprima) Per creare uno snapshot con ambito regionale in una regione consentita, includi il flag --region per indicare dove creare lo snapshot.

    gcloud beta compute snapshots create SNAPSHOT_NAME \
        --region=SNAPSHOT_SCOPE_REGION
        --source-disk=SOURCE_DISK_NAME \
        --source-disk-zone=SOURCE_ZONE \
        --snapshot-type=SNAPSHOT_TYPE
    

Sostituisci quanto segue:

  • SNAPSHOT_NAME: un nome per lo snapshot.
  • SOURCE_ZONE: La zona del disco di origine.
  • SOURCE_DISK_NAME: Il nome del volume del disco da cui vuoi creare uno snapshot.
  • SNAPSHOT_TYPE: il tipo di snapshot, STANDARD o ARCHIVE. Se non viene specificato un tipo di snapshot, viene creato uno snapshot STANDARD.
  • STORAGE_LOCATION: (facoltativo) per gli snapshot con ambito globale, la multi-regione Cloud Storage o la regione Cloud Storage in cui vuoi archiviare lo snapshot. Puoi specificare una sola località di archiviazione.

    Utilizza il parametro --storage-location solo se vuoi eseguire l'override della posizione di archiviazione predefinita personalizzata o predefinita indicata nelle impostazioni degli snapshot.

  • SNAPSHOT_SCOPE_REGION: (facoltativo) Per gli snapshot con ambito regionale, la regione a cui è applicato lo snapshot. Se includi questo parametro, non puoi utilizzare il parametro --storage-location. STORAGE_LOCATION viene impostato automaticamente su SNAPSHOT_SCOPE_REGION.

Per creare uno snapshot VSS di un Persistent Disk regionale, negli esempi precedenti sostituisci --source-disk-zone= con --source-disk-region= e specifica la regione in cui si trova il Persistent Disk regionale.

Google Cloud CLI attende che l'operazione restituisca lo stato READY, FAILED o raggiunga il timeout massimo e restituisce gli ultimi dettagli noti dello snapshot.

REST

Quando crei uno snapshot, per indicare che vuoi creare uno snapshot VSS, includi la proprietà guestFlush nel corpo della richiesta POST al metodo compute.snapshots.insert.

Puoi creare lo snapshot nella policy di posizione di archiviazione definita dalle impostazioni degli snapshot o utilizzando una posizione di archiviazione alternativa a tua scelta. Per saperne di più, vedi Scegliere la località di archiviazione degli snapshot.

  • Per creare uno snapshot nella posizione predefinita personalizzata o predefinita indicata nelle impostazioni degli snapshot, invia una richiesta POST al metodo snapshots.insert:

    POST https://compute.googleapis.com/compute/beta/projects/DESTINATION_PROJECT_ID/global/snapshots
    {
      "name": "SNAPSHOT_NAME",
      "sourceDisk": "projects/SOURCE_PROJECT_ID/zones/SOURCE_ZONE/disks/SOURCE_DISK_NAME",
      "snapshotType": "SNAPSHOT_TYPE",
      "guestFlush": true,
    }
    
  • In alternativa, per ignorare le impostazioni degli snapshot e crearne uno in una posizione di archiviazione personalizzata, invia una richiesta POST al metodo snapshots.insert e includi la proprietà storageLocations nella richiesta:

    POST https://compute.googleapis.com/compute/beta/projects/DESTINATION_PROJECT_ID/global/snapshots
    {
      "name": "SNAPSHOT_NAME",
      "sourceDisk": "projects/SOURCE_PROJECT_ID/zones/SOURCE_ZONE/disks/SOURCE_DISK_NAME",
      "snapshotType": "SNAPSHOT_TYPE",
      "storageLocations": [
          "STORAGE_LOCATION"
      ],
      "guestFlush": true,
    }
    
  • (Anteprima) Per creare uno snapshot con ambito regionale in una regione consentita, invia una richiesta POST al metodo snapshots.insert e definisci la regione di creazione:

    POST https://compute.googleapis.com/compute/beta/projects/DESTINATION_PROJECT_ID/regions/SNAPSHOT_SCOPE_REGION/snapshots
    {
        "name": "SNAPSHOT_NAME",
        "sourceDisk": "projects/SOURCE_PROJECT_ID/zones/SOURCE_ZONE/disks/SOURCE_DISK_NAME",
        "snapshotType": "SNAPSHOT_TYPE"
    }
    

Sostituisci quanto segue:

  • DESTINATION_PROJECT_ID: l'ID del progetto in cui vuoi creare lo snapshot.
  • SNAPSHOT_NAME: un nome per lo snapshot.
  • SOURCE_PROJECT_ID: l'ID del progetto del disco di origine.
  • SOURCE_ZONE: La zona del disco di origine.
  • SOURCE_DISK_NAME: Il nome del disco da cui vuoi creare uno snapshot.
  • SNAPSHOT_TYPE: il tipo di snapshot, STANDARD o ARCHIVE. Se non viene specificato un tipo di snapshot, viene creato uno snapshot STANDARD.
  • STORAGE_LOCATION: (facoltativo) per gli snapshot con ambito globale, la multi-regione Cloud Storage o la regione Cloud Storage in cui vuoi archiviare lo snapshot. Puoi specificare una sola località di archiviazione.

    Utilizza il parametro storageLocations solo se vuoi eseguire l'override della posizione di archiviazione predefinita personalizzata o predefinita indicata nelle impostazioni degli snapshot.

  • SNAPSHOT_SCOPE_REGION: (facoltativo) Per gli snapshot con ambito regionale, la regione a cui è applicato lo snapshot. Se includi questo parametro, non puoi utilizzare il parametro storageLocations. Il STORAGE_LOCATION viene impostato automaticamente su SNAPSHOT_SCOPE_REGION.

Per creare uno snapshot VSS di un Persistent Disk regionale, nelle richieste POST mostrate in precedenza, sostituisci la seguente riga:

"sourceDisk": "projects/SOURCE_PROJECT_ID/zones/SOURCE_ZONE/disks/SOURCE_DISK_NAME",
Utilizza questa riga quando crei uno snapshot di un Persistent Disk regionale:
"sourceDisk": "projects/SOURCE_PROJECT_ID/regions/SOURCE_REGION/disks/SOURCE_DISK_NAME",

Crea un disco scrivibile da uno snapshot VSS

Quando crei uno snapshot VSS, Windows Server contrassegna il volume nello snapshot come di sola lettura. Quando crei un nuovo disco dallo snapshot VSS, anche questo disco viene impostato in modalità di sola lettura.

Ciò potrebbe causare problemi. Ad esempio, se crei un'istanza VM con un nuovo disco di avvio da uno snapshot VSS di un disco di avvio esistente, il flag di sola lettura sul nuovo disco di avvio impedisce l'avvio corretto della VM.

Per risolvere questo problema, rimuovi il flag di sola lettura da qualsiasi nuovo disco creato da uno snapshot VSS seguendo questi passaggi:

  1. Assicurati che il disco sia collegato a una VM:

    • Se il disco creato dallo snapshot VSS è un disco di dati non di avvio, puoi collegarlo a qualsiasi VM nuova o esistente.
    • Se il disco creato dallo snapshot VSS è un disco di avvio e vuoi utilizzarlo per avviare una VM, devi collegarlo temporaneamente a una VM esistente separata. Dopo aver completato i seguenti passaggi, puoi scollegare il disco dalla VM e utilizzarlo per avviare una nuova istanza VM.
  2. Accedi alla VM Windows a cui è collegato il disco.

  3. Apri un prompt dei comandi di PowerShell ed esegui lo strumento diskpart.

    PS C:\> diskpart
    
  4. Identifica il disco che vuoi montare.

    DISKPART> list disk
    
  5. Utilizza il comando select disk per selezionare il disco.

    DISKPART> select disk DISK_NUMBER
    

    Sostituisci DISK_NUMBER con il numero del disco che vuoi montare.

  6. Monta il disco.

    DISKPART> online disk
    
  7. Elenca tutti i volumi nel disco.

    DISKPART> list volume
    
  8. Seleziona il nuovo volume.

    DISKPART> select volume VOLUME_NUMBER
    

    Sostituisci VOLUME_NUMBER con il numero del volume da configurare come lettura e scrittura.

  9. Deseleziona il flag di sola lettura.

    DISKPART> attr volume clear readonly hidden nodefaultdriveletter shadowcopy
    
  10. Esci dallo strumento diskpart.

    DISKPART> exit
    
  11. Se il disco è un disco di avvio per un'altra VM, sincronizza i file del disco di avvio con la nuova firma del disco.

    PS C:\> bcdboot DRIVE_LETTERWindows /s DRIVE_LETTER
    

    Sostituisci DRIVE_LETTER con la lettera di unità del volume che vuoi sincronizzare. Ad esempio, F per F:\.

Crea uno snapshot senza utilizzare VSS

In alcune situazioni, potresti voler creare snapshot di dischi collegati a VM Windows senza utilizzare VSS.

Per creare uno snapshot del disco su una VM Windows senza utilizzare VSS:

  1. Preparare il sistema per un'istantanea pulita
  2. Crea lo snapshot
  3. Rimontare il disco

Preparare il sistema per uno snapshot pulito

Prima di creare uno snapshot del disco, assicurati di acquisire uno snapshot coerente con lo stato che vuoi per il disco. Se acquisisci uno snapshot del disco in uno stato "non pulito", potrebbe essere necessario un controllo del disco e potrebbe verificarsi una perdita di dati. Prendi in considerazione la sincronizzazione e lo smontaggio del file system.

Sincronizzare il file system

Se lo smontaggio del disco non è un'opzione, ad esempio in scenari in cui un'applicazione potrebbe scrivere dati sul disco, puoi sincronizzare il file system per svuotare i buffer del disco. Per sincronizzare il file system:

  1. Accedi alla tua VM Windows.
  2. Scarica e installa lo strumento Sync di Microsoft.
  3. Impedisci alle tue applicazioni di scrivere sul disco.
  4. Apri una finestra del prompt dei comandi con privilegi elevati.
  5. Nella finestra della riga di comando, esegui:

    PS C:\> sync DRIVE_LETTER
    

    Sostituisci DRIVE_LETTER con la lettera di unità del volume che vuoi sincronizzare. Ad esempio, F per F:\.

Smonta il disco

  1. Accedi alla tua VM Windows.

  2. Apri un prompt dei comandi di PowerShell ed esegui lo strumento diskpart.

    PS C:\> diskpart
    
  3. Identifica il disco che vuoi smontare e di cui vuoi eseguire lo snapshot.

    DISKPART> list disk
    
  4. Successivamente, seleziona il disco utilizzando il numero che hai appena trovato.

    DISKPART> select disk DISK_NUMBER
    

    Sostituisci DISK_NUMBER con il numero del disco che vuoi rimontare.

  5. Smonta il disco.

    DISKPART> offline disk
    

Crea uno snapshot

Rimonta il disco

  1. Accedi alla tua VM Windows.

  2. Apri un prompt dei comandi di PowerShell ed esegui lo strumento diskpart.

    PS C:\> diskpart
    
  3. Identifica il disco che vuoi montare.

    DISKPART> list disk
    
  4. Utilizza il comando select disk per selezionare il disco.

    DISKPART> select disk DISK_NUMBER
    

    Sostituisci DISK_NUMBER con il numero del disco che vuoi montare.

  5. Monta il disco.

    DISKPART> online disk
    

Passaggi successivi