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 ulteriori informazioni sull'alta disponibilità, consulta la 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 regionale.
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 la disponibilità per regione e zona, seleziona Più zone (elevata disponibilità).
- Espandi Specifica zone.
- Seleziona le zone principali e secondarie. Le seguenti condizioni si applicano 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 con disponibilità elevata, 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 in cui 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 nel file di configurazione Terraform.
Prepara la directory
Ogni file di configurazione di Terraform deve avere una propria directory (chiamata anche modulo principale).
-
In Cloud Shell, crea una directory e un nuovo
file al suo interno. 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 campione in ogni sezione o passaggio.
Copia il codice campione nel
main.tf
appena creato.Se vuoi, copia il codice da GitHub. Questa 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 sta per creare o
aggiornare corrispondano alle tue aspettative:
terraform plan
Apporta le correzioni necessarie alla configurazione.
-
Applica la configurazione di Terraform eseguendo il seguente comando e inserendo
yes
al prompt: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 nell'interfaccia utente per assicurarti che Terraform le abbia create o aggiornate.
Elimina le modifiche
Per eliminare le modifiche:
- Per disattivare la protezione dell'eliminazione, imposta
l'argomento
deletion_protection
sufalse
nel file di configurazione Terraform.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 Creare 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.
- Nella sezione dell'opzione di configurazione Backup automatici e alta disponibilità, seleziona Alta disponibilità (regionale). Ti consigliamo inoltre di attivare l'opzione Backup automatici.
- Fai clic su Salva.
gcloud
Per configurare un'istanza come istanza regionale 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, 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 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, 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 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 verificare la risposta dell'applicazione 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 della tua istanza nel campo di testo e fai clic su Attiva failover.
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, 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 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 del campo
settingsVersion
.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 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, apporta 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 principali 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 principali e secondarie attuali dell'istanza.
Modificare le zone di un'istanza ad alta disponibilità
La modifica di una o entrambe le zone di un'istanza ad alta disponibilità esistente causa alcuni minuti di tempo di inattività durante la riconfigurazione dell'istanza. 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 zone e seleziona nuove zone. 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 o entrambe le zone principale e secondaria.
- 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 dell'istanza Cloud SQL.
- Se la zona secondaria è specificata, deve essere diversa dalla zona principale.
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.
- Le zone che scegli devono appartenere alla stessa regione dell'istanza 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.
Disattivare 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 la disponibilità elevata 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, 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/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 inclusi solo i failover automatici. |
Le risorse dell'istanza Cloud SQL (CPU e RAM) sono vicine al 100% di utilizzo, causando l'interruzione 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 al database.
- Scopri di più su Google Cloud Observability.