Condividi tramite


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

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

  1. In Esplora oggetti fare clic con il pulsante destro del mouse sull'istanza del server e scegliere Proprietà.

  2. 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

  1. 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

  1. 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.

  2. 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

  1. 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.

  2. Nel menu Start scegliere Tutti i programmi, Microsoft SQL Server 2014, Strumenti di configurazione e fare clic su Gestione configurazione SQL Server.

  3. 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à.

  4. Selezionare la scheda Disponibilità elevata AlwaysOn .

  5. 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.

  6. 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

  1. Impostare la directory (cd) su un'istanza del server che si desidera abilitare per Gruppi di disponibilità AlwaysOn.

  2. 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

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:

  1. 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).

  2. 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

  1. 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.

  2. Nel menu Start scegliere Tutti i programmi, Microsoft SQL Server 2014, Strumenti di configurazione e fare clic su Gestione configurazione SQL Server.

  3. 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à.

  4. 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.

  5. 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

  1. Passare alla directory (cd) a un'istanza del server attualmente abilitata che si vuole disabilitare per i gruppi di disponibilità AlwaysOn.

  2. 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:

  1. 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).

  2. Per rimuovere i metadati rimanenti, eliminare ogni gruppo di disponibilità interessato su un'istanza del server che fa parte del cluster WSFC originale.

  3. 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.

  4. 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 Servizio riavviato.
No Servizio non riavviato.
Servizio non riavviato.

Vedi anche

Panoramica dei gruppi di disponibilità AlwaysOn (SQL Server)
SERVERPROPERTY (Transact-SQL)