Aggiungere un database a un gruppo di disponibilità (SQL Server)
Questo argomento descrive come aggiungere un database a un gruppo di disponibilità AlwaysOn usando SQL Server Management Studio, Transact-SQL o PowerShell in SQL Server 2014.
Prima di iniziare:
Per aggiungere un database a un gruppo di disponibilità utilizzando:
Prima di iniziare
Prerequisiti e restrizioni
È necessario essere connessi all'istanza del server che ospita la replica primaria.
È necessario che il database risieda nell'istanza del server che ospita la replica primaria e sia conforme ai prerequisiti e alle restrizioni per i database di disponibilità. Per altre informazioni, vedere Prerequisiti, restrizioni e consigli per i gruppi di disponibilità AlwaysOn (SQL Server).
Sicurezza
Autorizzazioni
È necessaria l'autorizzazione ALTER AVAILABILITY GROUP nel gruppo di disponibilità, l'autorizzazione CONTROL AVAILABILITY GROUP, l'autorizzazione ALTER ANY AVAILABILITY GROUP o l'autorizzazione CONTROL SERVER.
Uso di SQL Server Management Studio
Per aggiungere un database a un gruppo di disponibilità
In Esplora oggetti connettersi all'istanza del server che ospita la replica primaria ed espandere l'albero del server.
Espandere il nodo Disponibilità elevata AlwaysOn e il nodo Gruppi di disponibilità .
Fare clic con il pulsante destro del mouse sul gruppo di disponibilità e selezionare uno dei comandi seguenti:
Per avviare la procedura guidata Aggiungi database a gruppo di disponibilità, selezionare il comando Aggiungi database . Per altre informazioni, vedere Usare la procedura guidata Aggiungi database a gruppo di disponibilità (SQL Server Management Studio).
Per aggiungere uno o più database specificandoli nella finestra di dialogo Proprietà gruppo di disponibilità , selezionare il comando Proprietà . Di seguito sono indicati i passaggi per l'aggiunta di un database:
Nel riquadro Database di disponibilità fare clic sul pulsante Aggiungi . Viene creato e selezionato un campo del database vuoto.
Immettere il nome di un database che soddisfi i prerequisiti dei database di disponibilità.
Per aggiungere un altro database, ripetere i passaggi precedenti. Dopo avere specificato i database, fare clic su OK per completare l'operazione.
Dopo avere utilizzato la finestra di dialogo Proprietà gruppo di disponibilità per aggiungere un database a un gruppo di disponibilità, è necessario configurare il database secondario corrispondente su ogni istanza del server che ospita una replica secondaria. Per altre informazioni, vedere Avviare lo spostamento dei dati in un database secondario AlwaysOn (SQL Server).
Uso di Transact-SQL
Per aggiungere un database a un gruppo di disponibilità
Connettersi all'istanza del server che ospita la replica primaria.
Utilizzare l'istruzione ALTER AVAILABILITY GROUP , come indicato di seguito:
ALTER AVAILABILITY GROUP nome_gruppo ADD DATABASE nome_database [,...n]
dove nome_gruppo è il nome del gruppo di disponibilità e nome_database è il nome di un database da aggiungere al gruppo.
Nell'esempio seguente viene aggiunto il database MyDb3 al gruppo di disponibilità MyAG .
-- Connect to the server instance that hosts the primary replica. -- Add an existing database to the availability group. ALTER AVAILABILITY GROUP MyAG ADD DATABASE MyDb3; GO
Dopo avere aggiunto un database a un gruppo di disponibilità, è necessario configurare il database secondario corrispondente su ogni istanza del server che ospita una replica secondaria. Per altre informazioni, vedere Avviare lo spostamento dei dati in un database secondario AlwaysOn (SQL Server).
Utilizzo di PowerShell
Per aggiungere un database a un gruppo di disponibilità
Spostarsi nella directory (
cd
) dell'istanza del server che ospita la replica primaria.Utilizzare il cmdlet
Add-SqlAvailabilityDatabase
.Ad esempio, con il comando seguente viene aggiunto il database secondario
MyDd
al gruppo di disponibilitàMyAG
la cui replica primaria è ospitata daPrimaryServer\InstanceName
.Add-SqlAvailabilityDatabase ` -Path SQLSERVER:\SQL\PrimaryServer\InstanceName\AvailabilityGroups\MyAG ` -Database "MyDb"
Nota
Per visualizzare la sintassi di un cmdlet, usare il
Get-Help
cmdlet nell'ambiente di PowerShell SQL Server. Per altre informazioni, vedere Get Help SQL Server PowerShell.Dopo avere aggiunto un database a un gruppo di disponibilità, è necessario configurare il database secondario corrispondente su ogni istanza del server che ospita una replica secondaria. Per altre informazioni, vedere Avviare lo spostamento dei dati in un database secondario AlwaysOn (SQL Server).
Per configurare e usare il provider di PowerShell SQL Server, vedere SQL Server provider di PowerShell.
Nel seguente esempio si illustra il processo completo di preparazione di un database secondario da un database nell'istanza del server che ospita la replica primaria di un gruppo di disponibilità, aggiungendo il database a un gruppo di disponibilità (come database primario), quindi creando un join del database secondario al gruppo di disponibilità. Nell'esempio si esegue innanzitutto il backup del database e del relativo log delle transazioni. Successivamente si ripristinano i backup del database e del log nelle istanze del server che ospitano una replica secondaria.
Nell'esempio viene chiamato due volte Add-SqlAvailabilityDatabase
, la prima volta nella replica primaria per aggiungere il database al gruppo di disponibilità, successivamente nella replica secondaria per creare un join del database secondario in quella replica al gruppo di disponibilità. Se si dispone di più di una replica secondaria, ripristinare e creare un join del database secondario in ognuna di esse.
$DatabaseBackupFile = "\\share\backups\MyDatabase.bak"
$LogBackupFile = "\\share\backups\MyDatabase.trn"
$MyAgPrimaryPath = "SQLSERVER:\SQL\PrimaryServer\InstanceName\AvailabilityGroups\MyAg"
$MyAgSecondaryPath = "SQLSERVER:\SQL\SecondaryServer\InstanceName\AvailabilityGroups\MyAg"
Backup-SqlDatabase -Database "MyDatabase" -BackupFile $DatabaseBackupFile -ServerInstance "PrimaryServer\InstanceName"
Backup-SqlDatabase -Database "MyDatabase" -BackupFile $LogBackupFile -ServerInstance "PrimaryServer\InstanceName" -BackupAction 'Log'
Restore-SqlDatabase -Database "MyDatabase" -BackupFile $DatabaseBackupFile -ServerInstance "SecondaryServer\InstanceName" -NoRecovery
Restore-SqlDatabase -Database "MyDatabase" -BackupFile $LogBackupFile -ServerInstance "SecondaryServer\InstanceName" -RestoreAction 'Log' -NoRecovery
Add-SqlAvailabilityDatabase -Path $MyAgPrimaryPath -Database "MyDatabase"
Add-SqlAvailabilityDatabase -Path $MyAgSecondaryPath -Database "MyDatabase"
Vedere anche
Panoramica di Gruppi di disponibilità AlwaysOn (SQL Server)
Creazione e configurazione di gruppi di disponibilità (SQL Server)
Utilizzare il Dashboard AlwaysOn (SQL Server Management Studio)
Monitorare Gruppi di disponibilità (Transact-SQL)