Abilitare e disabilitare la funzionalità Gruppi di disponibilità AlwaysOn (SQL Server)
L'abilitazione dei gruppi di disponibilità AlwaysOn è un prerequisito per un'istanza del server per l'uso dei gruppi di disponibilità. Prima di poter creare e configurare qualsiasi gruppo di disponibilità, è necessario abilitare la funzionalità Gruppi di disponibilità AlwaysOn in ogni istanza di SQL Server che ospiterà una replica di disponibilità per uno o più gruppi di disponibilità.
Importante
Se si elimina e si ricrea un cluster WSFC, è necessario disabilitare e riabilitare la funzionalità Gruppi di disponibilità AlwaysOn in ogni istanza di SQL Server che ospitava una replica di disponibilità nel cluster WSFC originale.
Prima di iniziare:
Procedure:
Prima di iniziare
Prerequisiti per l'abilitazione di Gruppi di disponibilità AlwaysOn
L'istanza del server deve trovarsi in un nodo WSFC (Windows Server Failover Clustering).
L'istanza del server deve eseguire un'edizione di SQL Server che supporta i gruppi di disponibilità AlwaysOn. Per ulteriori informazioni, vedere Features Supported by the Editions of SQL Server 2014.
Abilitare Gruppi di disponibilità AlwaysOn in una sola istanza del server per volta. Dopo aver abilitato i gruppi di disponibilità AlwaysOn, attendere il riavvio del servizio SQL Server prima di procedere a un'altra istanza del server.
Per informazioni sui prerequisiti aggiuntivi per la creazione e la configurazione dei gruppi di disponibilità, vedere Prerequisiti, restrizioni e consigli per i gruppi di disponibilità AlwaysOn (SQL Server).
Sicurezza
Mentre i gruppi di disponibilità AlwaysOn sono abilitati in un'istanza di SQL Server, l'istanza del server ha il controllo completo sul cluster WSFC.
Autorizzazioni
È richiesta l'appartenenza al gruppo degli amministratori nel computer locale, nonché il controllo totale nel cluster WSCF. Quando si abilita AlwaysOn tramite PowerShell, aprire la finestra del prompt dei comandi utilizzando l'opzione Esegui come amministratore .
Richiede le autorizzazioni per la gestione e la creazione degli oggetti di Active Directory.
Determinare se la funzionalità Gruppi di disponibilità AlwaysOn è abilitata
Utilizzo di SQL Server Management Studio
Per determinare se i gruppi di disponibilità AlwaysOn sono abilitati
In Esplora oggetti fare clic con il pulsante destro del mouse sull'istanza del server e scegliere Proprietà.
Nella finestra di dialogo Proprietà server scegliere la pagina Generale . Per la proprietà Is HADR Enabled è visualizzato uno dei valori seguenti:
True, se la funzionalità Gruppi di disponibilità AlwaysOn è abilitata
False, se la funzionalità Gruppi di disponibilità AlwaysOn è disabilitata.
Utilizzo di Transact-SQL
Per determinare se i gruppi di disponibilità AlwaysOn sono abilitati
Utilizzare l'istruzione SERVERPROPERTY seguente:
SELECT SERVERPROPERTY ('IsHadrEnabled');
L'impostazione della proprietà server indica se un'istanza
IsHadrEnabled
di SQL Server è abilitata per i gruppi di disponibilità AlwaysOn, come indicato di seguito:Se
IsHadrEnabled
= 1, la funzionalità Gruppi di disponibilità AlwaysOn è abilitata.Se
IsHadrEnabled
= 0, la funzionalità Gruppi di disponibilità AlwaysOn è disabilitata.
Nota
Per altre informazioni sulla proprietà del
IsHadrEnabled
server, vedere SERVERPROPERTY (Transact-SQL).
Con PowerShell
Per determinare se i gruppi di disponibilità AlwaysOn sono abilitati
Impostare il valore predefinito (
cd
) sull'istanza del server (ad esempio\SQL\NODE1\DEFAULT
) in cui si desidera determinare se i gruppi di disponibilità AlwaysOn sono abilitati.Eseguire il comando PowerShell
Get-Item
riportato di seguito:Get-Item . | Select IsHadrEnabled
Nota
Per visualizzare la sintassi di un cmdlet, usare il
Get-Help
cmdlet nell'ambiente PowerShell di SQL Server. Per altre informazioni, vedere Get Help SQL Server PowerShell.
Per impostare e utilizzare il provider PowerShell per SQL Server
Abilitare Gruppi di disponibilità AlwaysOn in Azure
Per abilitare AlwaysOn tramite:
Utilizzo di Gestione configurazione SQL Server
Per abilitare i gruppi di disponibilità AlwaysOn
Connettersi al nodo WSFC (Windows Server Failover Clustering) che ospita l'istanza di SQL Server in cui si desidera abilitare i gruppi di disponibilità AlwaysOn.
Nel menu Start scegliere Tutti i programmi, Microsoft SQL Server 2014, Strumenti di configurazione e fare clic su Gestione configurazione SQL Server.
In Gestione configurazione SQL Server fare clic su Servizi SQL Server, fare clic con il pulsante destro del mouse su SQL Server (
instance name
><), dove <instance name
> è il nome di un'istanza del server locale per cui si desidera abilitare i gruppi di disponibilità AlwaysOn e fare clic su Proprietà.Selezionare la scheda Disponibilità elevata AlwaysOn .
Verificare che nel campo Nome cluster di failover Windows sia incluso il nome del cluster di failover locale. Se il campo è vuoto, questa istanza del server non supporta attualmente Gruppi di disponibilità Always On. Il computer locale non è un nodo del cluster, il cluster WSFC è stato arrestato o questa edizione di SQL Server 2014 che non supporta i gruppi di disponibilità AlwaysOn.
Selezionare la casella di controllo Abilita gruppi di disponibilità AlwaysOn e scegliere OK.
Gestione configurazione SQL Server salva la modifica. È quindi necessario riavviare manualmente il servizio SQL Server. In questo modo è possibile scegliere un'ora per il riavvio che meglio soddisfa le esigenze aziendali. Quando il servizio SQL Server viene riavviato, AlwaysOn verrà abilitato e la
IsHadrEnabled
proprietà del server verrà impostata su 1.
Utilizzo di SQL Server PowerShell
Per abilitare AlwaysOn
Impostare la directory (
cd
) su un'istanza del server che si desidera abilitare per Gruppi di disponibilità AlwaysOn.Utilizzare il cmdlet
Enable-SqlAlwaysOn
per abilitare Gruppi di disponibilità AlwaysOn.Per visualizzare la sintassi di un cmdlet, usare il
Get-Help
cmdlet nell'ambiente PowerShell di SQL Server. Per altre informazioni, vedere Get Help SQL Server PowerShell.Nota
Per informazioni su come controllare se il cmdlet riavvia il
Enable-SqlAlwaysOn
servizio SQL Server, vedere When Does a Cmdlet Restart the SQL Server Service?, più avanti in questo argomento.
Per impostare e utilizzare il provider PowerShell per SQL Server
Esempio: Enable-SqlAlwaysOn
Il comando di PowerShell seguente abilita i gruppi di disponibilità AlwaysOn in un'istanza di SQL Server (Istanza computer\).
Enable-SqlAlwaysOn -Path SQLSERVER:\SQL\Computer\Instance
Disabilitare Gruppi di disponibilità AlwaysOn
Prima di disabilitare AlwaysOn:
Per disabilitare AlwaysOn utilizzando:
Completamento: dopo la disabilitazione di AlwaysOn
Importante
Disabilitare AlwaysOn in una sola un'istanza del server per volta. Dopo aver disabilitato i gruppi di disponibilità AlwaysOn, attendere il riavvio del servizio SQL Server prima di procedere a un'altra istanza del server.
Consigli
Prima di disabilitare AlwaysOn su un'istanza del server, si consiglia di eseguire le operazioni seguenti:
Se l'istanza del server sta attualmente ospitando la replica primaria di un gruppo di disponibilità che si desidera tenere, si consiglia di eseguire manualmente un failover sul gruppo di disponibilità a una replica secondaria sincronizzata, se possibile. Per altre informazioni, vedere Eseguire un failover manuale pianificato di un gruppo di disponibilità (SQL Server).
Rimuovere tutte le repliche secondarie locali. Per altre informazioni, vedere Rimuovere una replica secondaria da un gruppo di disponibilità (SQL Server).
Utilizzo di Gestione configurazione SQL Server
Per disabilitare AlwaysOn
Connettersi al nodo WSFC (Windows Server Failover Clustering) che ospita l'istanza di SQL Server in cui si desidera disabilitare i gruppi di disponibilità AlwaysOn.
Nel menu Start scegliere Tutti i programmi, Microsoft SQL Server 2014, Strumenti di configurazione e fare clic su Gestione configurazione SQL Server.
In Gestione configurazione SQL Server fare clic su Servizi SQL Server, fare clic con il pulsante destro del mouse su SQL Server (><
instance name
),dove <instance name
> è il nome di un'istanza del server locale per cui si desidera disabilitare i gruppi di disponibilità AlwaysOn e scegliere Proprietà.Deselezionare la casella di controlloAbilita gruppi di disponibilità AlwaysOnnella scheda Disponibilità elevata AlwaysOn e scegliere OK.
Gestione configurazione SQL Server salva le modifiche e riavvia il servizio SQL Server. Quando il servizio SQL Server viene riavviato, AlwaysOn verrà disabilitato e la
IsHadrEnabled
proprietà del server verrà impostata su 0 per indicare che i gruppi di disponibilità AlwaysOn sono disabilitati.Si consiglia di leggere le informazioni in Completamento: Dopo la disabilitazione di AlwaysOn, più avanti in questo argomento.
Utilizzo di SQL Server PowerShell
Per disabilitare AlwaysOn
Passare alla directory (
cd
) a un'istanza del server attualmente abilitata che si vuole disabilitare per i gruppi di disponibilità AlwaysOn.Utilizzare il cmdlet
Disable-SqlAlwaysOn
per abilitare Gruppi di disponibilità AlwaysOn.Ad esempio, il comando seguente permette di disabilitare la funzionalità Gruppi di disponibilità AlwaysOn in un'istanza di SQL Server (Computer\Instance). Il comando richiede il riavvio dell'istanza per cui verrà richiesta la conferma all'utente.
Disable-SqlAlwaysOn -Path SQLSERVER:\SQL\Computer\Instance
Importante
Per informazioni su come controllare se il cmdlet riavvia il
Disable-SqlAlwaysOn
servizio SQL Server, vedere When Does a Cmdlet Restart the SQL Server Service?, più avanti in questo argomento.Per visualizzare la sintassi di un cmdlet, usare il
Get-Help
cmdlet nell'ambiente PowerShell di SQL Server. Per altre informazioni, vedere Get Help SQL Server PowerShell.
Per impostare e utilizzare il provider PowerShell per SQL Server
Completamento: Dopo la disabilitazione di AlwaysOn
Dopo aver disabilitato i gruppi di disponibilità AlwaysOn, è necessario riavviare l'istanza di SQL Server. Gestione configurazione SQL Server riavvia l'istanza del server automaticamente. Tuttavia, se è stato utilizzato il cmdlet Disable-SqlAlwaysOn
, sarà necessario riavviare manualmente l'istanza del server. Per altre informazioni, vedere sqlservr Application.
Nell'istanza del server riavviata:
Poiché i database di disponibilità non vengono avviati insieme a SQL Server, non saranno accessibili.
L'unica istruzione Transact-SQL supportata è DROP AVAILABILITY GROUP. CREATE AVAILABILITY GROUP, ALTER AVAILABILITY GROUP e le opzioni SET HADR di ALTER DATABASE non sono supportate.
I metadati di SQL Server e i dati di configurazione dei gruppi di disponibilità AlwaysOn in WSFC non sono interessati disabilitando i gruppi di disponibilità AlwaysOn.
Se si disabilita in modo permanente Gruppi di disponibilità AlwaysOn su ogni istanza del server che ospita una replica di disponibilità per uno o più gruppi di disponibilità, si consiglia di completare i passaggi seguenti:
Se le repliche di disponibilità locali non sono state rimosse prima di disabilitare AlwaysOn, eliminare ogni gruppo di disponibilità per il quale l'istanza del server ospita una replica di disponibilità. Per informazioni sull'eliminazione di un gruppo di disponibilità, vedere Rimuovere un gruppo di disponibilità (SQL Server).
Per rimuovere i metadati rimanenti, eliminare ogni gruppo di disponibilità interessato su un'istanza del server che fa parte del cluster WSFC originale.
Tutti i database primari continuano a essere accessibili a tutte le connessioni, ma la sincronizzazione dei dati tra i database primario e secondario viene arrestata.
Per i database secondari viene impostato lo stato RESTORING. È possibile eliminare i database o ripristinarli tramite RESTORE WITH RECOVERY. Tuttavia, i database ripristinati non fanno più parte della sincronizzazione dei dati del gruppo di disponibilità.
Situazioni in cui un cmdlet comporta il riavvio del servizio SQL Server
In un'istanza del server attualmente in esecuzione, l'utilizzo di Enable-SqlAlwaysOn
o Disable-SqlAlwaysOn
per modificare l'impostazione AlwaysOn corrente può causare il riavvio del servizio SQL Server. Il comportamento del riavvio dipende dalle condizioni seguenti:
Specifica del parametro -NoServiceRestart | Specifica del parametro -Force | Il servizio SQL Server è stato riavviato? |
---|---|---|
No | No | Per impostazione predefinita. Tuttavia dal cmdlet è richiesto quanto segue: Per completare l'azione, è necessario riavviare il servizio SQL Server per l'istanza del server '<nome_istanza>'. Vuoi continuare? [Y] Sì [N] No [S] Sospendi [?] Guida (l'impostazione predefinita è "Y"): Se si specifica N o S, il servizio non viene riavviato. |
No | Sì | Servizio riavviato. |
Sì | No | Servizio non riavviato. |
Sì | Sì | Servizio non riavviato. |
Vedi anche
Panoramica dei gruppi di disponibilità AlwaysOn (SQL Server)
SERVERPROPERTY (Transact-SQL)