Eseguire il backup di database SQL nella macchina virtuale di Azure usando l'interfaccia della riga di comando di Azure
L'interfaccia della riga di comando di Azure consente di creare e gestire le risorse di Azure dalla riga di comando o tramite script. Questo articolo descrive come eseguire il backup di un database SQL nella macchina virtuale di Azure e attivare backup su richiesta usando l'interfaccia della riga di comando di Azure. È anche possibile eseguire queste azioni usando il portale di Azure.
Questo articolo presuppone che sia già installato un database SQL in una macchina virtuale di Azure. È anche possibile creare una macchina virtuale usando l'interfaccia della riga di comando di Azure.
In questo articolo si apprenderà come:
- Creare un insieme di credenziali di Servizi di ripristino
- Registrare SQL Server e individuare i database
- Abilitare il backup in un database SQL
- Attivare un backup su richiesta
Vedere gli scenari attualmente supportati per SQL nella macchina virtuale di Azure.
Prerequisiti
Usare l'ambiente Bash in Azure Cloud Shell. Per altre informazioni, vedere Avvio rapido per Bash in Azure Cloud Shell.
Se si preferisce eseguire i comandi di riferimento dell'interfaccia della riga di comando in locale, installare l'interfaccia della riga di comando di Azure. Per l'esecuzione in Windows o macOS, è consigliabile eseguire l'interfaccia della riga di comando di Azure in un contenitore Docker. Per altre informazioni, vedere Come eseguire l'interfaccia della riga di comando di Azure in un contenitore Docker.
Se si usa un'installazione locale, accedere all'interfaccia della riga di comando di Azure con il comando az login. Per completare il processo di autenticazione, seguire la procedura visualizzata nel terminale. Per altre opzioni di accesso, vedere Accedere con l'interfaccia della riga di comando di Azure.
Quando richiesto, installare l'estensione dell'interfaccia della riga di comando di Azure al primo uso. Per altre informazioni sulle estensioni, vedere Usare le estensioni con l'interfaccia della riga di comando di Azure.
Eseguire az version per trovare la versione e le librerie dipendenti installate. Per eseguire l'aggiornamento alla versione più recente, eseguire az upgrade.
Creare un insieme di credenziali di Servizi di ripristino
Un insieme di credenziali di Servizi di ripristino è un contenitore logico che archivia i dati di backup per ogni risorsa protetta, ad esempio macchine virtuali o carichi di lavoro di Azure in esecuzione in macchine virtuali di Azure, ad esempio database SQL o HANA. Quando viene eseguito, il processo di backup per una risorsa protetta crea un punto di ripristino all'interno dell'insieme di credenziali dei servizi di ripristino. È quindi possibile usare uno di questi punti di ripristino per ripristinare i dati a un dato momento.
Creare un insieme di credenziali di Servizi di ripristino con il comando az backup vault create . Usare il gruppo di risorse e la posizione come quella della macchina virtuale da proteggere. Informazioni su come creare una macchina virtuale usando l'interfaccia della riga di comando di Azure con questa guida introduttiva alla macchina virtuale.
Per questo articolo si userà:
- Un gruppo di risorse denominato SQLResourceGroup
- Una macchina virtuale denominata testSQLVM
- Risorse nella località westus2 .
Eseguire il comando seguente per creare un insieme di credenziali denominato SQLVault.
az backup vault create --resource-group SQLResourceGroup \
--name SQLVault \
--location westus2
Per impostazione predefinita, l'insieme di credenziali di Servizi di ripristino è impostato per l'archiviazione con ridondanza geografica. Geo-Redundant archiviazione garantisce che i dati di backup vengano replicati in un'area secondaria di Azure anche se si trova a centinaia di chilometri dall'area primaria. Se l'impostazione di ridondanza dell'archiviazione deve essere modificata, usare il comando az backup vault backup-properties set .
az backup vault backup-properties set \
--name SQLVault \
--resource-group SQLResourceGroup \
--backup-storage-redundancy "LocallyRedundant/GeoRedundant"
Per verificare se l'insieme di credenziali è stato creato correttamente, usare il comando az backup vault list . La risposta viene visualizzata come segue:
Location Name ResourceGroup
--------- --------------- -------------
westus2 SQLVault SQLResourceGroup
Registrare e proteggere il SQL Server
Per registrare il SQL Server con l'insieme di credenziali di Servizi di ripristino, usare il comando az backup container register. VMResourceId è l'ID risorsa della macchina virtuale creata per installare SQL.
az backup container register --resource-group SQLResourceGroup \
--vault-name SQLVault \
--workload-type SQLDataBase \
--backup-management-type AzureWorkload \
--resource-id VMResourceId
Nota
Se la macchina virtuale non è presente nello stesso gruppo di risorse dell'insieme di credenziali, SQLResourceGroup usa il gruppo di risorse in cui è stato creato l'insieme di credenziali.
La registrazione del server SQL individua automaticamente tutti i relativi database correnti. Tuttavia, per individuare eventuali nuovi database che potrebbero essere aggiunti in futuro, vedere la sezione Individuazione di nuovi database aggiunti alla sezione SQL Server registrata .
Usare il comando az backup container list per verificare se l'istanza di SQL è stata registrata correttamente con l'insieme di credenziali. La risposta viene visualizzata come segue:
Name Friendly Name Resource Group Type Registration Status
------------------------------------------------------ -------------- -------------------- --------- ----------------------
VMAppContainer;Compute;SQLResourceGroup;testSQLVM testSQLVM SQLResourceGroup AzureWorkload Registered
Nota
Il nome della colonna nell'output precedente fa riferimento al nome del contenitore. Questo nome del contenitore viene usato nelle sezioni successive per abilitare i backup e attivarli. Ad esempio, VMAppContainer; Calcolare; SQLResourceGroup;testSQLVM.
Abilitare il backup nel database SQL
Il comando az backup protectable-item list elenca tutti i database individuati nell'istanza DI SQL registrata nel passaggio precedente.
az backup protectable-item list --resource-group SQLResourceGroup \
--vault-name SQLVault \
--workload-type SQLDataBase \
--backup-management-type AzureWorkload \
--protectable-item-type SQLDataBase
--output table
È necessario trovare il database in questo elenco di cui si vuole eseguire il backup, che viene visualizzato come:
Name Protectable Item Type ParentName ServerName IsProtected
----------------------------- ---------------------- ------------ ----------- ------------
sqldatabase;mssqlserver;master SQLDataBase MSSQLServer testSQLVM NotProtected
sqldatabase;mssqlserver;model SQLDataBase MSSQLServer testSQLVM NotProtected
sqldatabase;mssqlserver;msdb SQLDataBase MSSQLServer testSQLVM NotProtected
Configurare ora il backup per sqldatabase;mssqlserver;database master .
Per configurare e proteggere i backup in un database, uno alla volta, usare il comando az backup protection enable-for-azurewl . Specificare il nome del criterio da usare. Per creare un criterio usando l'interfaccia della riga di comando, usare il comando az backup policy create . Per questo articolo sono stati usati i criteri testSQLPolicy .
az backup protection enable-for-azurewl --resource-group SQLResourceGroup \
--vault-name SQLVault \
--policy-name SQLPolicy \
--protectable-item-name "sqldatabase;mssqlserver;master" \
--protectable-item-type SQLDataBase \
--server-name testSQLVM \
--workload-type SQLDataBase \
--output table
È possibile usare lo stesso comando, se si dispone di un gruppo di disponibilità SQL Always On e si vuole identificare l'origine dati proteggibile all'interno del gruppo di disponibilità. In questo caso, il tipo di elemento proteggibile è SQLAG.
Per verificare se la configurazione di backup precedente è stata completata, usare il comando az backup job list . L'output viene visualizzato come segue:
Name Operation Status Item Name Start Time UTC
------------------------------------ --------------- --------- ---------- -------------------
e0f15dae-7cac-4475-a833-f52c50e5b6c3 ConfigureBackup Completed master 2019-12-03T03:09:210831+00:00
Il comando az backup job list elenca tutti i processi di backup (pianificati o su richiesta) eseguiti o attualmente in esecuzione nel database protetto, oltre ad altre operazioni, ad esempio registrare, configurare il backup ed eliminare i dati di backup.
Nota
Backup di Azure non regola automaticamente le modifiche all'ora legale durante il backup di un database SQL in esecuzione in una macchina virtuale di Azure.
Modificare manualmente i criteri in base alle esigenze.
Abilitare la protezione automatica
Per una configurazione di backup senza problemi, tutti i database aggiunti in futuro possono essere protetti automaticamente con un determinato criterio. Per abilitare la protezione automatica, usare il comando az backup protection auto-enable-for-azurewl .
Poiché l'istruzione consiste nel eseguire il backup di tutti i database futuri, l'operazione viene eseguita a livello di SQLInstance .
az backup protection auto-enable-for-azurewl --resource-group SQLResourceGroup \
--vault-name SQLVault \
--policy-name SQLPolicy \
--protectable-item-name "sqlinstance;mssqlserver" \
--protectable-item-type SQLInstance \
--server-name testSQLVM \
--workload-type MSSQL\
--output table
Attivare un backup su richiesta
Per attivare un backup su richiesta, usare il comando az backup protection backup-now .
Nota
Il periodo di conservazione di questo backup è determinato dal tipo di backup su richiesta eseguito.
- Il backup completo su richiesta mantiene i backup per un minimo di 45 giorni e un massimo di 99 anni.
- La copia su richiesta accetta solo qualsiasi valore per la conservazione.
- Il differenziale su richiesta mantiene il backup in base alla conservazione dei differenziali pianificati impostati nei criteri.
- Il log su richiesta mantiene i backup in base alla conservazione dei log pianificati impostati nei criteri.
az backup protection backup-now --resource-group SQLResourceGroup \
--item-name sqldatabase;mssqlserver;master \
--vault-name SQLVault \
--container-name VMAppContainer;Compute;SQLResourceGroup;testSQLVM \
--backup-type Full
--retain-until 01-01-2040
--output table
L'output viene visualizzato come segue:
Name ResourceGroup
------------------------------------ -------------
e0f15dae-7cac-4475-a833-f52c50e5b6c3 sqlResourceGroup
La risposta fornisce il nome del processo. È possibile usare questo nome di processo per tenere traccia dello stato del processo usando il comando az backup job show .
Passaggi successivi
- Informazioni su come ripristinare un database SQL nella macchina virtuale di Azure usando l'interfaccia della riga di comando.
- Informazioni su come eseguire il backup di un database SQL in esecuzione nella macchina virtuale di Azure usando portale di Azure.