Cloud Composer 1 | Cloud Composer 2 | Cloud Composer 3
Questa pagina descrive come configurare ambienti Cloud Composer estremamente resilienti.
Informazioni sulla resilienza per gli errori zonali in Cloud Composer
Gli ambienti Cloud Composer altamente resilienti utilizzano meccanismi di ridondanza e failover integrati che riducono la suscettibilità dell'ambiente a guasti zonali e interruzioni di single point of failure.
Ad esempio, un'interruzione zonale interrompe le attività Airflow eseguite in una zona specifica. In seguito, un ambiente altamente resiliente si riprende, riavvia la sua componenti interessati in una zona diversa e passa il database a una in una zona secondaria. Di conseguenza, le attività Airflow non riuscite possono essere riprogrammate e riavviate da Airflow, preservando al contempo la cronologia delle esecuzioni del DAG e altre impostazioni.
Un ambiente altamente resiliente viene eseguito in almeno due zone di un ambiente selezionato regione. Cloud Composer distribuisce automaticamente i componenti del tuo ambiente tra le zone.
Puoi utilizzare ambienti Cloud Composer altamente resilienti per processi aziendali critici.
Informazioni sul database ad alta disponibilità del tuo ambiente
Negli ambienti Cloud Composer ad alta disponibilità, l'istanza Cloud SQL che memorizza il database dell'ambiente viene eseguita in modalità ad alta disponibilità. Un'istanza Cloud SQL configurata per l'alta disponibilità è chiamata anche istanza a livello di regione e si trova in una zona principale e secondaria all'interno della regione configurata. All'interno di un'istanza a livello di regione, la configurazione include un'istanza principale e un'istanza in standby.
In caso di interruzione, l'istanza Cloud SQL del tuo ambiente esegue il failover automatico del database nella configurazione Cloud SQL in standby in esecuzione in un'istanza Compute Engine. Non è necessario eseguire altre azioni nell'ambiente Cloud Composer. Quando la zona principale è operativa di nuovo, l'ambiente torna ad avere due zone (principale e secondaria). In alcuni casi, le zone principali e secondarie possono essere scambiate. L'istanza Cloud SQL in modalità ad alta disponibilità utilizza lo stesso indirizzo IP dopo un failover.
Informazioni sui componenti Airflow ad alta disponibilità
Gli ambienti Cloud Composer ad alta disponibilità eseguono componenti Airflow distribuiti tra le zone.
Il tuo ambiente esegue sempre esattamente due scheduler Airflow, due server web, e almeno due (ma non più di dieci) triggerer se gli attivatori sono abilitati. Queste coppie di vengono eseguiti in zone separate. Il numero minimo di worker è impostato su due, e il cluster del tuo ambiente distribuisce le istanze worker tra le zone. Nella a livello di zona, le istanze worker interessate vengono riprogrammate zona diversa.
Per ulteriori informazioni sull'architettura degli ambienti altamente resilienti, consulta Architettura di ambienti altamente resilienti.
Prima di iniziare
Sono disponibili ambienti altamente resilienti solo negli ambienti IP privati.
Vengono offerti ambienti altamente resilienti con un addebito incrementale rispetto ai in ambienti regolari.
Gli ambienti altamente resilienti sono disponibili in Cloud Composer versione 2.2.0 e successive.
Se vuoi aggiornare un ambiente standard in uno altamente resiliente, assicurati che soddisfi i seguenti requisiti di configurazione. Se il tuo ambiente non soddisfa questi requisiti, puoi aggiornarne i parametri di scalabilità e rendimento.
- Il numero minimo di worker di Airflow è 2 o più.
- Il numero di scheduler Airflow è esattamente 2.
- Se utilizzi operatori posticipabili nei tuoi DAG, almeno 2 attivatori.
Crea un ambiente altamente resiliente
Per creare un ambiente altamente resiliente, abilita la modalità di elevata resilienza quando crei un ambiente.
Aggiorna un ambiente standard alla modalità ad alta resilienza
Console
Nella console Google Cloud, vai alla pagina Ambienti.
Nell'elenco degli ambienti, fai clic sul nome del tuo ambiente. Si apre la pagina Dettagli ambiente.
Seleziona la scheda Configurazione dell'ambiente.
Nella sezione Modalità di resilienza, fai clic su Modifica.
Seleziona Alta resilienza e fai clic su Salva.
gcloud
gcloud composer environments update ENVIRONMENT_NAME \
--location LOCATION \
--enable-high-resilience
Sostituisci quanto segue:
ENVIRONMENT_NAME
: il nome dell'ambiente.LOCATION
: la regione in cui si trova l'ambiente.
API
Crea una richiesta API
environments.patch
.In questa richiesta:
Nel parametro
updateMask
, specifica la mascheraconfig.resilienceMode
.Nel corpo della richiesta, specifica
HIGH_RESILIENCE
per passare alla modalità di elevata resilienza.
Esempio:
// PATCH https://composer.googleapis.com/v1/projects/example-project/
// locations/us-central1/environments/example-environment?updateMask=
// config.resilienceMode
{
"config": {
"resilience_mode": { "HIGH_RESILIENCE" }
}
}
Terraform
Il campo resilience_mode
nel blocco config
specifica la modalità di resilienza. Per utilizzare la modalità ad alta resilienza, imposta questo valore su HIGH_RESILIENCE
.
resource "google_composer_environment" "example" {
provider = google-beta
name = "ENVIRONMENT_NAME"
region = "LOCATION"
config {
resilience_mode = "HIGH_RESILIENCE"
}
}
Sostituisci quanto segue:
ENVIRONMENT_NAME
: il nome dell'ambiente.LOCATION
: la regione in cui si trova l'ambiente.
Esempio:
resource "google_composer_environment" "example" {
provider = google-beta
name = "example-environment"
region = "us-central1"
config {
resilience_mode = "HIGH_RESILIENCE"
}
Passare da un ambiente altamente resiliente alla modalità di resilienza standard
Puoi impostare l'ambiente in modalità di resilienza standard in qualsiasi momento. Questo operazione:
- Riduci il numero di server web nel tuo ambiente a 1.
- Disattiva la modalità di alta disponibilità del database Airflow dell'ambiente.
Non modifica le impostazioni per il numero minimo di worker, schedulatori o attivatori Airflow.
Console
Nella console Google Cloud, vai alla pagina Ambienti.
Nell'elenco degli ambienti, fai clic sul nome del tuo ambiente. Viene visualizzata la pagina Dettagli dell'ambiente.
Seleziona la scheda Configurazione dell'ambiente.
Nella sezione Modalità di resilienza, fai clic su Modifica.
Seleziona Resilienza standard (predefinita) e fai clic su Salva.
gcloud
gcloud composer environments update ENVIRONMENT_NAME \
--location LOCATION \
--disable-high-resilience
Sostituisci quanto segue:
ENVIRONMENT_NAME
: il nome dell'ambiente Cloud ComposerLOCATION
: la regione in cui si trova l'ambiente.
API
Creare una richiesta API
environments.patch
.In questa richiesta:
Nel parametro
updateMask
, specifica Mascheraconfig.resilienceMode
.Nel corpo della richiesta, specifica
RESILIENCE_MODE_UNSPECIFIED
per passare alla modalità di resilienza standard.
Esempio:
// PATCH https://composer.googleapis.com/v1/projects/example-project/
// locations/us-central1/environments/example-environment?updateMask=
// config.resilienceMode
{
"config": {
"resilience_mode": { "RESILIENCE_MODE_UNSPECIFIED" }
}
}
Terraform
Il campo resilience_mode
nel blocco config
specifica la modalità di resilienza. Per utilizzare la modalità di resilienza standard, imposta questo valore su
STANDARD_RESILIENCE
.
resource "google_composer_environment" "example" {
provider = google-beta
name = "ENVIRONMENT_NAME"
region = "LOCATION"
config {
resilience_mode = "STANDARD_RESILIENCE"
}
}
Sostituisci quanto segue:
ENVIRONMENT_NAME
: il nome dell'ambiente.LOCATION
: la regione in cui si trova l'ambiente.
Esempio:
resource "google_composer_environment" "example" {
provider = google-beta
name = "example-environment"
region = "us-central1"
config {
resilience_mode = "STANDARD_RESILIENCE"
}
Verifica se l'ambiente funziona in modalità di elevata resilienza
Console
Nella console Google Cloud, vai alla pagina Ambienti.
Nell'elenco degli ambienti, fai clic sul nome dell'ambiente. Viene visualizzata la pagina Dettagli dell'ambiente.
Seleziona la scheda Configurazione dell'ambiente.
Nella sezione Modalità di resilienza, visualizza la modalità di resilienza del tuo completamente gestito di Google Cloud.
gcloud
Per verificare se la modalità di elevata resilienza è abilitata nel tuo ambiente, esegui il seguente comando Google Cloud CLI. Il valore True
indica che
sia abilitata nel tuo ambiente.
gcloud composer environments describe ENVIRONMENT_NAME \
--location LOCATION \
--format="value(config.resilienceMode)"
Sostituisci quanto segue:
ENVIRONMENT_NAME
: il nome dell'ambiente Cloud ComposerLOCATION
: la regione in cui si trova l'ambiente.
Passaggi successivi
- Esegui test di failover per il tuo ambiente altamente resiliente.
- Ripristino di emergenza con snapshot dell'ambiente