Scegli l'API di bilanciamento del carico multi-cluster per GKE


Questa pagina ti aiuta a scegliere l'API più adatta per il deployment dei bilanciatori del carico per distribuire il traffico su una flotta di cluster Google Kubernetes Engine (GKE).

Puoi collegare un bilanciatore del carico al tuo parco di cluster GKE nei seguenti modi:

  1. Utilizza le API Multi Cluster Ingress, ad esempio le risorse Multi Cluster Ingress e MultiClusterService.

  2. Utilizza le API Gateway (risorse GatewayClass, Gateway, HTTPRoute, Policy, ServiceExport e ServiceImport).

  3. Configura il bilanciatore del carico delle applicazioni utilizzando la console Google Cloud , gcloud CLI, API, Terraform, Config Connector e collega i NEG autonomi ai servizi di backend gestiti dall'utente.

La tabella seguente elenca i diversi modi in cui puoi collegare un bilanciatore del carico al tuo parco di cluster GKE. Qualsiasi funzionalità elencata nella pagina Confronto delle funzionalità del bilanciatore del carico che non è elencata nella tabella seguente dovrebbe funzionare con un bilanciatore del carico gestito dall'utente con NEG autonomi, anziché basarsi sull'API nativa di Kubernetes per il bilanciamento del carico.

Soluzione: Ingress multi-cluster Gateway multi-cluster Bilanciatore del carico gestito dall'utente con NEG standalone
Supporto della piattaforma GKE
Fase di lancio del prodotto GA GA GA
Versioni di GKE Enterprise / Standard Enterprise / Standard Enterprise / Standard
Modalità cluster Standard / Autopilot Standard / Autopilot Standard / Autopilot
Versione GKE 1.18 e versioni successive GKE 1.24 e versioni successive per Standard e 1.26 e versioni successive per Autopilot 1.18 e versioni successive
Architettura e componenti
Controller Kubernetes gestito da Google
Controller Controller Ingress multi-cluster GKE GKE Gateway Controller -
Posizione del controller Off-cluster

(Google Cloud infrastruttura)

Off-cluster

(Google Cloud infrastruttura)

-
API API Kubernetes native API Kubernetes native Google Cloud API (gcloud CLI)
Risorse API MultiClusterIngress, MultiClusterService GatewayClass, Gateway, HTTPRoute, *Policy -
Fase di lancio dell'API GA (v1) GA (v1) -
Abilitazione dell'API su GKE Impostazione del cluster su Autopilot / Standard Impostazione predefinita su Autopilot

Impostazione del cluster su Standard

-
Supporto di servizi multi-cluster
Servizi multi-cluster (MCS) richiesti
Versione dell'API MCS networking.gke.io/v1 net.gke.io/v1 -
Tipo di risorsa MultiClusterService ServiceExport -
Licenza Soluzione proprietaria Open source -
Gestione del ciclo di vita delle risorse Cloud Networking (escluso VPC condiviso)
Gestione automatizzata degli indirizzi IP frontend
Gestione automatizzata del bilanciatore del carico Cloud
  • Regola di forwarding
  • Proxy di destinazione
  • Mappa URL
  • Servizi di backend
  • Controlli di integrità
Gestione automatizzata dei gruppi di endpoint di rete (NEG)

(Solo NEG a livello di zona)

(Solo NEG a livello di zona)

(Solo NEG zonali, annotazione obbligatoria sul servizio Kubernetes)

Gestione di Cloud NGFW

(solo regole firewall VPC, regole gestite)

(solo regole firewall VPC, regole gestite)

Supporto per il VPC condiviso
Cluster e parco risorse (hub) nel progetto host
Cluster e parco risorse (hub) nello stesso progetto di servizio

(con autorizzazioni per le regole firewall nel progetto host)

(con autorizzazioni per le regole firewall nel progetto host)

Cluster e parco risorse (hub) in progetti diversi

(con riferimento ai servizi tra progetti)

Supporto dei bilanciatori del carico
Bilanciatori del carico delle applicazioni
Classico
Esterno globale
Esterno regionale
Interno a livello di regione
Interno tra regioni
Bilanciatori del carico di rete proxy
Classico
Esterno globale
Esterno regionale
Interno (sempre regionale)
Bilanciatori del carico di rete passthrough
Esterno (sempre regionale)
Interno (sempre regionale)
Supporto dei protocolli client-to-load-balancer
HTTP, HTTPS, HTTP/2
WebSocket
HTTP/3 (basato su IETF QUIC)
SSL (TLS) o TCP
Supporto dei backend del bilanciatore del carico
Pod (NEG a livello di zona)
Macchine virtuali (inclusi i nodi GKE)

(Sconsigliato)

Altri backend:
  • Cloud Storage
  • Endpoint esterni pubblici (NEG internet)
  • Endpoint esterni privati (NEG ibridi)
  • NEG Private Service Connect (PSC)
  • Cloud Run (NEG serverless)
Supporto dei protocolli dal bilanciatore del carico ai backend
HTTP, HTTPS, HTTP/2 (uno dei tre)
WebSocket
SSL (TLS) o TCP (uno dei due)
Indirizzamento IP e protocolli
Assegnazione dinamica degli indirizzi IP
Assegnazione di indirizzi IP statici
Stesso indirizzo IP per più porte (HTTP, HTTPS)
IPv6

(Il traffico dal bilanciatore del carico al backend rimane IPv4)

(Il traffico dal bilanciatore del carico al backend rimane IPv4)

(Il traffico dal bilanciatore del carico al backend rimane IPv4)

Gestione del routing e del traffico
Accesso globale
Bilanciamento del carico tra progetti
Routing host/percorso

(Corrispondenza esatta, prefisso)

(Corrispondenza esatta, prefisso)

Routing basato sull'intestazione

(Corrispondenza esatta)

Reindirizzamenti percorso
Riscritture degli URL
Suddivisione del traffico
Mirroring del traffico
Trasferimento del traffico
Scalabilità automatica basata sul traffico
Intestazioni delle richieste personalizzate
Intestazioni delle risposte personalizzate
Routing tra spazi dei nomi
Sicurezza frontend
Policy SSL
Reindirizzamento da HTTP a HTTPS
Supporto di più certificati TLS
Certificati basati sui secret Kubernetes
Certificati SSL con gestione indipendente
Certificati SSL gestiti da Google
Supporto di Certificate Manager
Proprietà del servizio di backend
Timeout per svuotamento della connessione
Affinità sessione
Configurazione della registrazione dell'accesso HTTP
Timeout del servizio di backend
Configurazione personalizzata del controllo di integrità del bilanciatore del carico

(BackendConfig)

(HealthCheckPolicy)

(gcloud CLI / Google Cloud console / Terraform)

TLS ai servizi di backend
Backend predefinito personalizzato
Cloud CDN

(Non tutte le funzionalità)

(Tutte le funzionalità)

Identity-Aware Proxy (IAP)
Criterio di sicurezza di Google Cloud Armor

Passaggi successivi