Questa pagina descrive come configurare un'istanza per l'alta disponibilità.
Puoi configurare un'istanza per l'alta disponibilità al momento della creazione o attivare l'alta disponibilità su un'istanza esistente.
Per saperne di più sull'alta disponibilità, consulta Panoramica della configurazione dell'alta disponibilità.
Crea una nuova istanza configurata per l'alta disponibilità
Quando crei un'istanza e la configuri per l'alta disponibilità, Cloud SQL la crea come istanza a livello di regione
Per creare un'istanza configurata per l'alta disponibilità:
Console
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Seleziona Crea istanza.
- Seleziona il motore del database.
- Nella sezione Scegli regione e disponibilità a livello di zona, seleziona Più zone (disponibilità elevata).
- Espandi Specifica zone.
- Seleziona le zone principali e secondarie. Le seguenti condizioni
si applica quando la zona secondaria viene utilizzata durante la creazione o la modifica dell'istanza:
- Per impostazione predefinita, le zone sono
Any
per la zona principale eAny (different from primary)
per la zona secondaria.
Se sono specificate entrambe le zone, devono essere diverse.
- Per impostazione predefinita, le zone sono
- Fai clic su Salva.
Tornerai alla pagina dell'istanza principale mentre l'istanza viene aggiornata.
gcloud
- Crea l'istanza regionale:
gcloud sql instances create REGIONAL_INSTANCE_NAME \ --availability-type=REGIONAL \ --database-version=SQLSERVER_2017_STANDARD \ --cpu=NUMBER_CPUS \ --memory=MEMORY_SIZE
- Configura l'utente root:
gcloud sql users set-password root no-host \ --instance=REGIONAL_INSTANCE_NAME \ --password=PASSWORD
Terraform
Per creare un'istanza ad alta disponibilità, utilizza una risorsa Terraform.
Applica le modifiche
Per applicare la configurazione Terraform in un progetto Google Cloud, completa i passaggi nelle seguenti sezioni.
Prepara Cloud Shell
- Avvia Cloud Shell.
-
Imposta il progetto Google Cloud predefinito dove vuoi applicare le configurazioni Terraform.
Devi eseguire questo comando una sola volta per progetto e puoi farlo in qualsiasi directory.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
Le variabili di ambiente vengono sostituite se imposti valori espliciti in Terraform di configurazione del deployment.
Prepara la directory
Ogni file di configurazione Terraform deve avere una directory dedicata (inoltre chiamato modulo principale).
-
In Cloud Shell, crea una directory e un nuovo
all'interno di quella directory. Il nome file deve avere l'estensione
.tf
, ad esempiomain.tf
. In questo tutorial, il file è denominatomain.tf
.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
Se stai seguendo un tutorial, puoi copiare il codice di esempio in ogni sezione o passaggio.
Copia il codice campione nel nuovo oggetto
main.tf
.Se vuoi, copia il codice da GitHub. Opzione consigliata quando lo snippet Terraform fa parte di una soluzione end-to-end.
- Esamina e modifica i parametri di esempio da applicare al tuo ambiente.
- Salva le modifiche.
-
Inizializza Terraform. Devi eseguire questa operazione una sola volta per directory.
terraform init
Se vuoi, per utilizzare la versione più recente del provider Google, includi l'opzione
-upgrade
:terraform init -upgrade
Applica le modifiche
-
Rivedi la configurazione e verifica che le risorse che Terraform creerà o
che l'aggiornamento soddisfi le tue aspettative:
terraform plan
Apporta le correzioni necessarie alla configurazione.
-
Applica la configurazione Terraform eseguendo questo comando e inserendo
yes
alla richiesta:terraform apply
Attendi che Terraform mostri il messaggio "Applicazione completata".
- Apri il tuo progetto Google Cloud per visualizzare i risultati. Nella console Google Cloud, vai alle risorse nella UI per assicurarti create o aggiornate da Terraform.
Elimina le modifiche
Per eliminare le modifiche:
- Per disabilitare la protezione dall'eliminazione, imposta il file di configurazione Terraform
Argomento
deletion_protection
perfalse
.deletion_protection = "false"
- Applica la configurazione Terraform aggiornata eseguendo il seguente comando e inserendo
yes
al prompt:terraform apply
-
Rimuovi le risorse applicate in precedenza con la configurazione Terraform eseguendo il seguente comando e inserendo
yes
al prompt:terraform destroy
REST v1
Per l'elenco completo dei parametri per la richiesta, consulta la pagina instances:insert.Crea l'istanza regionale.
-
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-name: il nome dell'istanza
- database-version: la stringa enum della versione del database
- region La regione Google Cloud
- machine-type Il tipo di macchina
Metodo HTTP e URL:
POST https://sqladmin.googleapis.com/v1/projects/project-id/instances
Corpo JSON della richiesta:
{ "name": "instance-name", "region": "region", "databaseVersion": "database-version", "settings": { "tier": "machine-type", "backupConfiguration": { "enabled": true }, "availabilityType": "REGIONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
- Al termine dell'inizializzazione dell'istanza, aggiorna la password di root sull'istanza:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-id: l'ID istanza
- password: la nuova password dell'utente root
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/users?host=%25&name=sqlserver'
Corpo JSON della richiesta:
{ "name": "sqlserver", "host": "nohost", "password": "password"}
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
REST v1beta4
Per l'elenco completo dei parametri per la richiesta, consulta la pagina instances:insert.Crea l'istanza regionale.
-
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-name: il nome dell'istanza
- database-version: la stringa enum della versione del database
- region La regione Google Cloud
- machine-type Il tipo di macchina
Metodo HTTP e URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances
Corpo JSON della richiesta:
{ "name": "instance-name", "region": "region", "databaseVersion": "database-version", "settings": { "tier": "machine-type", "backupConfiguration": { "enabled": true }, "availabilityType": "REGIONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
- Al termine dell'inizializzazione dell'istanza, aggiorna la password di root sull'istanza:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-id: l'ID istanza
- password: la nuova password dell'utente root
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/users?host=%25&name=sqlserver'
Corpo JSON della richiesta:
{ "name": "sqlserver", "host": "nohost", "password": "password"}
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
Per maggiori dettagli sulla creazione di un'istanza, consulta Creazione di istanze.
Configurare un'istanza esistente per l'alta disponibilità
Puoi configurare un'istanza Cloud SQL per l'alta disponibilità utilizzando la console Google Cloud, gcloud CLI o l'API.
Console
Per configurare un'istanza per l'alta disponibilità:
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
- Fai clic su Modifica.
- Nell'opzione di configurazione Backup automatici e alta disponibilità seleziona Alta disponibilità (a livello di regione). È inoltre consigliato di attivare i backup automatici.
- Fai clic su Salva.
gcloud
Per configurare un'istanza in modo che sia regionale e ad alta disponibilità, utilizza il comando gcloud sql instances patch
:
gcloud sql instances patch INSTANCE_NAME \ --availability-type REGIONAL
Sostituisci INSTANCE_NAME con il nome dell'istanza Cloud SQL che stai configurando per l'alta disponibilità.
REST v1
Per configurare un'istanza come istanza regionale ad alta disponibilità:
Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza che stai configurando per l'alta disponibilità
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"availabilityType": "REGIONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
REST v1beta4
Per configurare un'istanza come istanza regionale ad alta disponibilità:
Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza che stai configurando per l'alta disponibilità
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"availabilityType": "REGIONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
Avvia il failover
Il test del failover è facoltativo, ma è consigliato per consentirti di vedere come dell'applicazione risponde in caso di failover.
Per scoprire di più sui failover, consulta la panoramica del failover.
Console
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
- Fai clic su Failover.
- Nella finestra di dialogo Attiva manualmente un failover, inserisci l'ID l'istanza nel campo di testo e fai clic su Failover attivatore.
gcloud
Avvia il failover:
gcloud sql instances failover PRIMARY_INSTANCE_NAME
REST v1
- Descrivi l'istanza principale per ottenere il valore del campo
settingsVersion
.Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza che stai configurando per l'alta disponibilità
Metodo HTTP e URL:
GET https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "SQLSERVER_2019_STANDARD" }
- Avvia il failover:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-name: il nome dell'istanza
- settings-version: la versione delle impostazioni da instanceInfo
Metodo HTTP e URL:
POST https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-name/failover
Corpo JSON della richiesta:
{ "failoverContext": { "settingsVersion":"settings-version" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
REST v1beta4
- Descrivi l'istanza principale per ottenere il valore dell'oggetto
campo
settingsVersion
.Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza che stai configurando per l'alta disponibilità
Metodo HTTP e URL:
GET https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "SQLSERVER_2019_STANDARD" }
- Avvia il failover:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-name: il nome dell'istanza
- settings-version: la versione delle impostazioni da instanceInfo
Metodo HTTP e URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-name/failover
Corpo JSON della richiesta:
{ "failoverContext": { "settingsVersion":"settings-version" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
Viene eseguito il failover dell'istanza e non è disponibile per il servizio dati per alcuni minuti.
Verificare la configurazione dell'alta disponibilità di un'istanza
Per verificare che un'istanza abbia l'alta disponibilità e per visualizzare le zone in cui è in esecuzione:
Console
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
- Verifica che le seguenti impostazioni di alta disponibilità siano visualizzate nella sezione Configurazione:
- Disponibilità elevata (a livello di regione)
- Località mostra la zona principale corrente dell'istanza.
gcloud
gcloud sql instances describe INSTANCE_NAME
L'output indica che availabilityType
è REGIONAL
.
I campi gceZone
e secondaryGceZone
mostrano le zone principali e secondarie attuali dell'istanza.
REST v1
Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-id: l'ID istanza
Metodo HTTP e URL:
GET https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "SQLSERVER_2019_STANDARD" }
L'output indica che availabilityType
è REGIONAL
.
I campi gceZone
e secondaryGceZone
mostrano
le zone primarie e secondarie attuali dell'istanza.
REST v1beta4
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- project-id: l'ID progetto
- instance-id: l'ID istanza
Metodo HTTP e URL:
GET https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere una risposta JSON simile alla seguente:
{ "kind": "sql#instance", "state": "RUNNABLE", "databaseVersion": "SQLSERVER_2017_STANDARD", }
L'output indica che availabilityType
è REGIONAL
.
I campi gceZone
e secondaryGceZone
mostrano
le zone primarie e secondarie attuali dell'istanza.
Modifica le zone di un'istanza ad alta disponibilità
La modifica di una o entrambe le zone di un'istanza ad alta disponibilità esistente provoca un di qualche minuto di inattività mentre l'istanza viene riconfigurata. Per visualizzare le zone principali e secondarie attuali in cui è in esecuzione l'istanza ad alta disponibilità, consulta Verificare la configurazione dell'alta disponibilità di un'istanza.
Per modificare le zone di un'istanza ad alta disponibilità:
Console
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
- Fai clic su Modifica.
- Nella sezione Scegli la disponibilità per regione e zona, espandi
Specifica le zone e selezionane di nuove. Per impostazione predefinita, le zone sono
Any
per la zona principale eAny (different from primary)
per la zona secondaria. Si applicano le seguenti limitazioni:- Puoi specificare solo la zona principale oppure sia quella primaria che quella secondaria zone.
- Se sono specificate entrambe le zone, devono essere zone diverse.
- Fai clic su Salva.
Tornerai alla pagina dell'istanza principale mentre l'istanza viene aggiornata.
gcloud
Modifica la zona in cui è in esecuzione l'istanza:
gcloud sql instances patch INSTANCE_NAME \ --zone=PRIMARY_ZONE --secondary-zone=SECONDARY_ZONE
Il parametro --secondary-zone
è facoltativo. Se la ometti,
Cloud SQL selezionerà una zona disponibile diversa dalla
zona principale.
Si applicano le seguenti limitazioni:
- Le zone devono essere zone valide appartenenti alla stessa regione di Cloud SQL.
- Se viene specificata la zona secondaria, deve essere diversa da quella principale zona di destinazione.
REST v1
Modifica le zone dell'istanza regionale:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- PROJECT_ID: l'ID progetto
- INSTANCE_NAME: il nome dell'istanza
- PRIMARY_ZONE: la zona principale
- SECONDARY_ZONE: la zona secondaria
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"locationPreference": {"zone": "PRIMARY_ZONE", "secondaryZone": "SECONDARY_ZONE"}} }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
Il parametro
secondaryZone
è facoltativo. Se la ometti, Cloud SQL selezionerà una zona disponibile diversa dalla zona principale.Si applicano le seguenti limitazioni:
- Le zone devono essere zone valide.
- Qualsiasi zona che scegli deve appartenere alla stessa regione di Cloud SQL.
REST v1beta4
Modifica le zone dell'istanza regionale:
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- PROJECT_ID: l'ID progetto
- INSTANCE_NAME: il nome dell'istanza
- PRIMARY_ZONE: la zona principale
- SECONDARY_ZONE: la zona secondaria
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"locationPreference": {"zone": "PRIMARY_ZONE", "secondaryZone": "SECONDARY_ZONE"}} }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
Il parametro
secondaryZone
è facoltativo. Se la ometti, Cloud SQL selezionerà una zona disponibile diversa dalla zona principale.Si applicano le seguenti limitazioni:
- Le zone devono essere zone valide.
- Le zone che scegli devono appartenere alla stessa regione dell'istanza Cloud SQL.
Disattiva l'alta disponibilità per un'istanza
Puoi disattivare l'alta disponibilità per un'istanza Cloud SQL utilizzando la console Google Cloud, gcloud CLI o l'API.
Console
Per disattivare l'alta disponibilità per un'istanza:
-
Nella console Google Cloud, vai alla pagina Istanze Cloud SQL.
- Per aprire la pagina Panoramica di un'istanza, fai clic sul nome dell'istanza.
- Fai clic su Modifica.
- Apri Backup automatici.
- Nella sezione Disponibilità, fai clic su Zona singola.
- Fai clic su Salva. Questa modifica richiede il riavvio dell'istanza.
- Quando viene visualizzata la finestra di dialogo, fai clic su Salva e riavvia.
gcloud
Per disattivare l'alta disponibilità per un'istanza, utilizza il comando gcloud sql instances patch
:
gcloud sql instances patch INSTANCE_NAME \ --availability-type ZONAL
Sostituisci INSTANCE_NAME con il nome dell'istanza Cloud SQL per cui stai disattivando l'alta disponibilità.
REST v1
Per modificare il tipo di disponibilità dell'istanza in ZONAL
, utilizza il metodo instances:patch
. Questo metodo disattiva l'alta disponibilità per l'istanza.
Prima di utilizzare i dati della richiesta, apporta le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza per cui stai disattivando l'alta disponibilità
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"availabilityType": "ZONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
REST v1beta4
Per modificare il tipo di disponibilità dell'istanza in ZONAL
, utilizza il metodo instances:patch
. Questo metodo disattiva l'alta disponibilità per l'istanza.
Prima di utilizzare i dati della richiesta, effettua le seguenti sostituzioni:
- PROJECT_ID: l'ID o il numero di progetto del progetto Google Cloud che contiene l'istanza
- INSTANCE_NAME: il nome dell'istanza per cui stai disattivando l'alta disponibilità
Metodo HTTP e URL:
PATCH https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/INSTANCE_NAME
Corpo JSON della richiesta:
{ "settings": {"availabilityType": "ZONAL" } }
Per inviare la richiesta, espandi una di queste opzioni:
Dovresti ricevere un codice di stato di operazione riuscita (2xx) e una risposta vuota.
Risoluzione dei problemi
Problema | Risoluzione dei problemi |
---|---|
Non riesci a trovare le metriche per un failover manuale. | Nelle metriche vengono presi in considerazione solo i failover automatici. |
Le risorse delle istanze Cloud SQL (CPU e RAM) utilizzano quasi il 100% di utilizzo, causando l'arresto dell'istanza ad alta disponibilità. | La dimensione dell'istanza della macchina è troppo piccola per il carico.
Modifica l'istanza per eseguire l'upgrade a una dimensione della macchina più grande per ottenere più CPU e memoria. |
Passaggi successivi
- Scopri di più su come funziona la configurazione dell'alta disponibilità.
- Testa la risposta dell'applicazione alle connessioni perse riavviando l'istanza.
- Scopri di più sulla gestione delle connessioni ai database.
- Scopri di più su Google Cloud Observability.