Panoramica della gestione avanzata del traffico per le API di bilanciamento del carico

Questo documento è rivolto agli amministratori di mesh o piattaforme e servizi sviluppatori che hanno un livello di familiarità con queste Concetti di Cloud Service Mesh e mesh di servizi e chi determina e configura il modo il traffico viene gestito in un deployment Cloud Service Mesh. Questo documento si applica solo alle API di bilanciamento del carico, non alle API di routing dei servizi. Se le tue Il deployment di Cloud Service Mesh utilizza le API di routing dei servizi; consulta Panoramica della gestione avanzata del traffico.

Cloud Service Mesh offre funzionalità avanzate di gestione del traffico che ti offrono e un controllo granulare sulla modalità di gestione del traffico. Cloud Service Mesh supporta i seguenti casi d'uso:

  • Routing granulare del traffico delle richieste a uno o più servizi
  • Suddivisione del traffico in base alla ponderazione per distribuire il traffico tra più servizi
  • Criteri di mirroring del traffico che inviano richieste a un servizio di debug e in un altro
  • Distribuzione del traffico ottimizzata nei backend di un servizio per migliorare il carico bilanciamento

Queste funzionalità avanzate di gestione del traffico consentono di in termini di disponibilità e prestazioni. Uno dei vantaggi dell'utilizzo Cloud Service Mesh per questi casi d'uso consente di aggiornare il modo in cui il traffico è gestito senza dover modificare il codice dell'applicazione.

  • Quando utilizzi il proxy HTTP di destinazione per configurare i proxy Envoy per inviare HTTP richieste, tutte le funzionalità di questo documento sono disponibili.

  • Quando utilizzi servizi o applicazioni gRPC senza proxy con Cloud Service Mesh, alcune funzionalità non sono disponibili.

  • Quando utilizzi il proxy TCP di destinazione per configurare i proxy Envoy per inviare la comunicazione TCP richieste, nessuna delle funzionalità è disponibile perché non esiste una mappa URL nelle configurazioni con un proxy TCP di destinazione.

Per ulteriori dettagli, consulta la pagina Funzionalità.

Per configurare la gestione avanzata del traffico, utilizza la stessa mappa di regole di routing e le risorse dei servizi di backend che utilizzi durante la configurazione di Cloud Service Mesh. Cloud Service Mesh, a sua volta, configura i proxy Envoy e gRPC senza proxy per applicare i criteri avanzati di gestione del traffico impostati verso l'alto.

A livello generale, svolgi le seguenti operazioni:

  1. Configura la mappa di regole di routing in modo da eseguire le operazioni indicate di seguito, in base al caratteristiche della richiesta in uscita:

    1. Seleziona il servizio di backend a cui vengono instradate le richieste.

    2. Se vuoi, puoi eseguire altre azioni.

  2. Configura il servizio di backend per controllare la distribuzione del traffico a backend ed endpoint dopo la selezione di un servizio di destinazione.

Configurazione filtri

Una delle responsabilità principali di Cloud Service Mesh è generare configurazione le informazioni dalla regola di forwarding, dal proxy di destinazione e dalla mappa URL, quindi ai client Cloud Service Mesh, ad esempio proxy Envoy e gRPC diverse applicazioni. Cloud Service Mesh controlla il mesh di servizi inviando informazioni di configurazione ai clienti, che indicano come comportarsi per indirizzare il traffico: Cloud Service Mesh è il piano di controllo.

Quando crei o aggiorni le informazioni di configurazione in Cloud Service Mesh, Cloud Service Mesh traduce questa configurazione in un linguaggio che i suoi clienti possano comprendere. Per impostazione predefinita, Cloud Service Mesh lo condivide configurazione con tutti i suoi client. In alcuni casi, potresti voler adattare quali client Cloud Service Mesh ricevono specifiche informazioni di configurazione, altre parole, filtrano la configurazione in base a client specifici.

Sebbene si tratti di una funzionalità avanzata, i seguenti esempi illustrano quando configurazione dei filtri può aiutarti a:

  • La tua organizzazione utilizza il modello di networking VPC condiviso e più i team utilizzano Cloud Service Mesh in diversi progetti di servizio. Se isolare la configurazione da altri progetti di servizio, filtrando la configurazione in modo che client Cloud Service Mesh specifici ricevono solo un sottoinsieme della configurazione.
  • Hai configurato un numero molto elevato di regole di route e servizi Cloud Service Mesh e vuoi evitare di inviare una quantità insolitamente grande di a ogni client Cloud Service Mesh. Tieni presente che un cliente che deve valutare una richiesta in uscita utilizzando un modello potrebbe funzionare meno bene di un client che deve solo valutare una richiesta usando una configurazione semplificata.

I filtri di configurazione si basano sul concetto di filtri dei metadati:

  1. Quando un client Cloud Service Mesh si connette, presenta informazioni da il suo file di bootstrap in Cloud Service Mesh.
  2. Queste informazioni includono i contenuti dei campi dei metadati, sotto forma di coppie chiave-valore, specificate nel file di bootstrap durante il deployment i tuoi proxy Envoy e le tue applicazioni gRPC.
  3. Puoi aggiungere filtri di metadati alla regola di forwarding. La viene filtrata l'intera configurazione collegata alla regola di forwarding.
  4. Puoi aggiungere filtri di metadati sulla mappa URL. Il filtro dei metadati viene applicato in base al routing del percorso.
  5. Cloud Service Mesh condivide la configurazione solo con i client che presentano che corrispondano alle condizioni di filtro dei metadati.

Per informazioni su come configurare i filtri di metadati per Envoy, consulta Imposta il filtro della configurazione in base alla corrispondenza MetadataFilter.

Routing del traffico e azioni

In Cloud Service Mesh, la mappa di regole di routing si riferisce alla combinazione di regola di forwarding, proxy di destinazione e mappa URL Google Cloud. Tutte le funzionalità avanzate di gestione del traffico relative a routing e le azioni vengono configurate usando la mappa URL.

Le seguenti sezioni descrivono le funzionalità avanzate di gestione del traffico che che puoi impostare nella mappa di regole di routing.

Gestione delle richieste

Quando un client invia una richiesta, questa viene gestita come descritto seguenti passaggi:

  1. La richiesta è abbinata a una mappa di regole di routing specifica come segue:

    • Se utilizzi Envoy:

      • L'indirizzo IP e la porta di destinazione della richiesta vengono confrontati Indirizzo IP e porta delle regole di forwarding in tutte le mappe di regole di routing. Solo le mappe di regole di routing con regole di forwarding che hanno viene preso in considerazione lo schema di bilanciamento del carico INTERNAL_SELF_MANAGED.
      • La regola di forwarding che corrisponde alla richiesta fa riferimento a un HTTP di destinazione o gRPC, che fa riferimento a una mappa URL. Questa mappa URL contiene informazioni utilizzate per il routing e le azioni.
    • Se utilizzi gRPC senza proxy:

      • Un client gRPC che utilizza lo schema di risoluzione dei nomi xds non esegui una ricerca DNS per risolvere il nome host nell'URI del canale. Questo client risolve invece hostname[:port] nella destinazione URI inviando un valore LDS a Cloud Service Mesh.
      • Solo la porta di un forwarding viene confrontata con lo schema di bilanciamento del carico INTERNAL_SELF_MANAGED alla porta nell'URI di destinazione (ad esempio, xds:///example.hostname:8080). L'IP dell'indirizzo della regola di forwarding. Il valore predefinito La porta è 80 se non è specificata nessuna porta nell'URI di destinazione.
      • La regola di forwarding che corrisponde ai riferimenti alla richiesta un proxy gRPC di destinazione, che fa riferimento a una mappa URL. Questa mappa URL contiene informazioni utilizzate per il routing e le azioni.
      • Se più di una regola di forwarding corrisponde alla richiesta, l'URL mappa che contiene la regola host che corrisponde a hostname[:port] in l'URI di destinazione viene utilizzato per il routing e le azioni.
  2. Una volta determinata la mappa URL appropriata, quest'ultima viene valutati per determinare il servizio di backend di destinazione e, facoltativamente, e applicare azioni.

  3. Dopo aver selezionato il servizio di backend di destinazione, il traffico viene distribuito tra i backend o gli endpoint per quel servizio di backend di destinazione, in base configurazione nella risorsa del servizio di backend.

Il secondo passaggio è descritto nella sezione seguente. Routing semplice basato su host e percorso. Il terzo passaggio prevede discussi in Routing e azioni avanzati.

Routing semplice basato su host e percorso

Cloud Service Mesh supporta uno schema di routing semplificato e una schema avanzato. Nello schema semplice, specifichi un host e, facoltativamente, un percorso. L'host e il percorso della richiesta vengono valutati per determinare il servizio verso a cui indirizzare una richiesta:

  • L'host della richiesta è la parte del nome di dominio di un URL, ad esempio la parte host dell'URL http://example.com/video/ è example.com.
  • Il percorso della richiesta è la parte dell'URL che segue il nome host, Ad esempio, la porzione del percorso dell'URL http://example.com/video/ è /video.

Puoi configurare un routing semplice in base all'host e al percorso nella mappa di regole di routing, consiste di quanto segue:

  • Una regola di forwarding globale
  • Un proxy HTTP di destinazione, un proxy HTTPS di destinazione o un proxy gRPC di destinazione
  • Una mappa URL

La maggior parte della configurazione viene eseguita nella mappa URL. Dopo aver creato mappa di regole di routing iniziale, devi modificare solo la parte della mappa URL della mappa di regole di routing. Nel diagramma seguente, le regole del percorso hanno azioni in modo simile alle azioni nel prossimo diagramma.

Routing basato sulle risorse host e del percorso.
Routing basato sulle risorse host e percorso (fai clic per ingrandire)

La regola più semplice è una regola predefinita, in cui devi specificare solo un carattere jolly (*) e un matcher del percorso con un servizio predefinito. Dopo la creazione la regola predefinita, puoi aggiungere altre regole che specificano host percorsi di addestramento. Le richieste in uscita vengono valutate in base a queste regole nel modo seguente:

  • Se l'host di una richiesta (ad esempio example.com) corrisponde a una regola host:

    1. Successivamente viene valutato il matcher percorso.
    2. Ogni matcher di percorso contiene una o più regole di percorso che vengono valutate rispetto al percorso della richiesta.
    3. Se viene trovata una corrispondenza, la richiesta viene indirizzata al servizio specificato la regola del percorso.
    4. Se la regola host corrisponde, ma nessuna regola di percorso corrisponde, le richieste vengono instradate a un predefinito contenuto in ogni matcher percorso.
  • Se la richiesta non corrisponde a nessuna delle regole host specificate, viene instradato al servizio specificato nella regola predefinita.

Per saperne di più sui campi delle risorse della mappa URL e sul loro funzionamento, consulta la pagina dell'API REST urlMaps.

Routing e azioni avanzate

Se vuoi fare qualcosa di più che eseguire il routing di una richiesta in base all'host e puoi impostare regole avanzate per instradare le richieste ed eseguire azioni.

Routing avanzato.
Routing avanzato (fai clic per ingrandire)

A livello generale, il routing e le azioni avanzati funzionano come segue:

  1. Come nel caso del routing semplice, l'host della richiesta viene confrontato con l'host che configuri nella mappa URL. Se l'host di una richiesta corrisponde a un host viene valutato il matcher percorso della regola host.
  2. Il matcher di percorso contiene una o più regole di route valutate rispetto alla richiesta. Queste regole di route vengono valutate in ordine di priorità abbinando gli attributi della richiesta (host, percorso, intestazione e query specifici) in base a condizioni di corrispondenza specifiche, ad esempio del prefisso.
  3. Dopo aver selezionato una regola di route, puoi applicare azioni. Il valore predefinito è indirizzare la richiesta a un singolo servizio di destinazione, ma può configurare anche altre azioni.

Routing avanzato

Il routing avanzato è simile al routing semplice descritto in precedenza, tranne per il fatto che puoi specificare la priorità delle regole e ulteriori conditions.

Con il routing avanzato, devi specificare una priorità unica per ogni regola. Questo la priorità determina l'ordine in cui vengono valutate le regole di route, con valori valori di priorità che hanno la precedenza sui valori di priorità più alti. Dopo una richiesta corrisponde a una regola, questa viene applicata e le altre vengono ignorate.

Il routing avanzato supporta anche condizioni di corrispondenza aggiuntive. Ad esempio, puoi specificare che una regola corrisponde all'intestazione di una richiesta se il nome di quest'ultima corrisponde esattamente o solo parzialmente, ad esempio in base al prefisso o al suffisso. Una regola può avere una corrispondenza in base alla valutazione del nome dell'intestazione rispetto a una normale o su altri criteri, come il controllo della presenza di un'intestazione.

Per ulteriori condizioni di corrispondenza e dettagli per headerMatches e queryParameterMatches, consulta le API REST urlMaps.

Combinando i parametri host, percorso, intestazione e query con priorità e corrispondenze di traffico, puoi creare regole altamente espressive che si adattano al traffico requisiti di gestione. Per maggiori dettagli consulta la tabella seguente.

Applicazione basata su HTTP Applicazione basata su gRPC
Confronto tra host HTTP e host gRPC

L'host è la parte del nome di dominio dell'URL che l'applicazione che ti chiama.

Ad esempio, la parte dell'URL relativa all'host http://example.com/video/ è example.com.

L'host è il nome utilizzato dal client nell'URI del canale connettersi a un servizio specifico.

Ad esempio, la parte host dell'URI del canale xds:///example.com è example.com.

Percorsi HTTP e percorsi gRPC

Il percorso è la parte dell'URL che segue il nome host.

Ad esempio, la parte del percorso dell'URL http://example.com/video è /video.

Il percorso si trova nell'intestazione :path della richiesta HTTP/2 e assomiglia a /SERVICE_NAME/METHOD_NAME.

Ad esempio, se chiami il metodo Download nella Example servizio gRPC, i contenuti L'intestazione :path assomiglia a /Example/Download.

Altre intestazioni gRPC (metadati) gRPC supporta l'invio metadati tra il client gRPC e il server gRPC per fornire informazioni su una chiamata RPC. Questi metadati si presentano in formato coppie chiave-valore trasportate come intestazioni nella richiesta HTTP/2.

Azioni

Cloud Service Mesh ti consente di specificare le azioni che il tuo Envoy le applicazioni gRPC senza proxy prendono in considerazione la gestione delle richieste. Le seguenti azioni può essere configurato utilizzando Cloud Service Mesh.

Azione Nome campo API Descrizione
Reindirizzamenti urlRedirect Restituisce un codice di risposta 3xx configurabile. Imposta anche intestazione della risposta Location con l'URI appropriato, sostituendo l'host e il percorso come specificato nell'azione di reindirizzamento.
Riscrittura URL urlRewrite Riscrive la parte dell'URL relativa al nome host, la parte del percorso dell'URL, o entrambi, prima di inviare una richiesta al servizio di backend selezionato.
Trasformazioni intestazione headerAction Aggiunge o rimuove le intestazioni della richiesta prima di inviare una richiesta al di servizio di backend. Può anche aggiungere o rimuovere le intestazioni delle risposte dopo o ricevere una risposta dal servizio di backend.
Mirroring del traffico requestMirrorPolicy

Oltre a inoltrare la richiesta al backend selezionato invia una richiesta identica al backend di mirroring configurato su un incendio e dimenticarsi. Il bilanciatore del carico non attende una risposta dal backend a cui invia la richiesta sottoposta a mirroring.

Il mirroring è utile per testare una nuova versione di un servizio di backend. Puoi utilizzarla anche per eseguire il debug degli errori di produzione in una versione di debug al servizio di backend anziché nella versione di produzione.

Suddivisione del traffico in base alla ponderazione weightedBackendServices

Consente di distribuire il traffico di una regola con corrispondenza in più di backend, proporzionale a un peso definito dall'utente assegnato un singolo servizio di backend.

Questa funzionalità è utile per configurare deployment a fasi o A/B. test. Ad esempio, l'azione di route potrebbe essere configurata in modo che Il 99% del traffico viene inviato a un servizio che esegue una di un'applicazione, mentre l'1% del traffico viene inviato separato che esegue una versione più recente dell'applicazione.

Nuovi tentativi retryPolicy Configura le condizioni in cui i nuovi tentativi del bilanciatore del carico non sono riusciti richieste, quanto tempo attende il bilanciatore del carico prima di riprovare il numero massimo di nuovi tentativi consentiti.
Timeout timeout Specifica il timeout per la route selezionata. Il timeout è stato calcolato dal momento dell'elaborazione completa della richiesta fino al momento in cui la risposta viene elaborata completamente. Il timeout include tutti i nuovi tentativi.
Fault injection faultInjectionPolicy Introduce errori durante la gestione delle richieste per simulare gli errori, tra cui alta latenza, sovraccarico del servizio, errori del servizio e rete il partizionamento orizzontale. Questa funzionalità è utile per testare la resilienza di un per risolvere gli errori simulati.
Criteri di sicurezza corsPolicy I criteri di condivisione delle risorse tra origini (CORS) gestiscono le impostazioni per forzando l'applicazione delle richieste CORS.

Per ulteriori informazioni sulle azioni e su come funzionano, vedi urlMaps API REST.

In ogni regola di route, puoi specificare una delle seguenti azioni di route (chiamate Azioni principali nella console Google Cloud):

  • Instrada il traffico a un singolo servizio (service)
  • Suddividi traffico tra più servizi (weightedBackendServices)
  • URL di reindirizzamento (urlRedirect)

Inoltre, puoi combinare una qualsiasi delle azioni di percorso menzionate in precedenza con una o più delle seguenti azioni di route (indicate come Azioni dei componenti aggiuntivi nella console Google Cloud):

  • Manipolare le intestazioni di richiesta/risposta (headerAction)
  • Mirroring del traffico (requestMirrorPolicy)
  • Riscrivi l'host dell'URL, il percorso o entrambi (urlRewrite)
  • Riprova richieste non riuscite (retryPolicy)
  • Imposta timeout (timeout)
  • Introduci gli errori a una percentuale del traffico (faultInjectionPolicy)
  • Aggiungi criterio CORS (corsPolicy)

Poiché le azioni sono associate a regole di route specifiche, il proxy Envoy o un'applicazione gRPC senza proxy può applicare azioni diverse in base alla richiesta che gestisce.

Distribuzione del traffico tra i backend di un servizio

Come descritto in Gestione delle richieste, Quando un client gestisce una richiesta in uscita, seleziona prima una destinazione completamente gestito di Google Cloud. Dopo aver selezionato un servizio di destinazione, deve capire quale deve ricevere la richiesta dal backend o dall'endpoint.

Distribuzione del traffico tra i backend.
Distribuzione del traffico tra i backend (fai clic per ingrandire)

Nel diagramma precedente, la regola è stata semplificata. La regola è in genere una regola host, uno strumento di abbinamento del percorso e una o più regole di percorso o route. La di destinazione è il servizio(backend). Backend 1, ... e Il backend riceve e gestisce la richiesta. Questi backend potrebbero essere, ad esempio le istanze di macchine virtuali (VM) Compute Engine che ospitano lato server il codice dell'applicazione.

Per impostazione predefinita, il client che gestisce la richiesta invia richieste con il backend integro più vicino con capacità. Per evitare di sovraccaricare utilizza l'algoritmo di bilanciamento del carico Round Robin per bilanciare richieste successive su altri backend del servizio di destinazione. In alcuni casi, tuttavia, potresti volere un controllo più granulare comportamento degli utenti.

Bilanciamento del carico, affinità sessione e protezione dei backend

Per ogni servizio puoi impostare i seguenti criteri di distribuzione del traffico.

Norme Nome campo API Descrizione
Modalità di bilanciamento del carico balancingMode Controlla in che modo un gruppo di endpoint di rete (NEG) o un'istanza gestita gruppo (MIG) viene selezionato dopo che è stato eseguito un servizio di destinazione selezionato. Puoi configurare la modalità di bilanciamento per distribuire il carico in base alle connessioni simultanee e tasso di richieste.
Criterio di bilanciamento del carico localityLbPolicy Imposta l'algoritmo di bilanciamento del carico utilizzato per distribuire il traffico tra i backend all'interno di un NEG o un gruppo di istanze gestite. Per ottimizzare il rendimento, puoi scegliere tra vari algoritmi (come round robin o minima richiesta).
Affinità sessione sessionAffinity

Fornisce un tentativo di invio delle richieste basato sul criterio del "best effort" da un particolare client allo stesso backend per tutto il tempo per cui il backend è integro e ha capacità.

Cloud Service Mesh supporta quattro opzioni di affinità sessione: indirizzo IP client, HTTP basato su cookie, HTTP basato su intestazioni e dell'affinità cookie generato (che Cloud Service Mesh genera automaticamente).

Hash coerente consistentHash Fornisce un'affinità sessione software basata su intestazioni HTTP, cookie o altre proprietà.
Interruttori di sicurezza circuitBreakers Imposta limiti superiori per il volume di connessioni e richieste per a un servizio di backend.
Rilevamento outlier outlierDetection Specifica i criteri per (1) rimuovere i backend in stato non integro da MIG o NEG e (2) aggiungere un backend quando è considerato sufficientemente integro da ricevere traffico di nuovo. Il controllo di integrità associato al servizio determina se un backend o un endpoint sono considerati integri.

Per ulteriori informazioni sulle varie opzioni di distribuzione del traffico e come funzionano, consulta le backendServices API REST.

Esempi di casi d'uso

La gestione avanzata del traffico è applicabile a molti casi d'uso. Questa sezione fornisce una alcuni esempi di alto livello.

Puoi trovare altri esempi, incluso il codice campione, nella Configurare la gestione avanzata del traffico e Configurazione di servizi gRPC proxyless con gestione avanzata del traffico guide.

Routing del traffico granulare per la personalizzazione

Puoi instradare il traffico a un servizio in base ai parametri della richiesta. Per Ad esempio, potresti usare questo servizio per offrire un'esperienza più personalizzata per gli utenti Android. Nel diagramma seguente, Cloud Service Mesh configura al tuo mesh di servizi per inviare richieste con l'intestazione user-agent:Android al tuo servizio Android anziché il servizio generico.

Routing basato sull'intestazione user agent impostata su Android.
Routing basato sull'intestazione user-agent impostata su Android (fai clic per ingrandire)

Suddivisione del traffico in base alla ponderazione per deployment più sicuri

Il deployment di una nuova versione di un servizio di produzione esistente può essere rischioso. Uniforme una volta superati i test in un ambiente di test, potrebbe essere utile non eseguire il routing gli utenti alla nuova versione.

Cloud Service Mesh ti consente di definire le suddivisioni del traffico basate sui pesi da distribuire e il traffico su più servizi. Ad esempio, puoi inviare l'1% del traffico alla nuova versione del servizio, controlla che tutto funzioni e poi gradualmente aumentare la proporzione di traffico diretto al nuovo servizio.

Suddivisione del traffico basata sui pesi di Cloud Service Mesh.
Suddivisione del traffico basata sui pesi di Cloud Service Mesh (fai clic per ingrandire)

Mirroring del traffico per il debug

Quando esegui il debug di un problema, potrebbe essere utile inviare copie dei file di produzione a un servizio di debug, Cloud Service Mesh ti consente di configurare la richiesta i criteri di mirroring in modo che le richieste vengano inviate a un servizio e a copie di questi vengono inviate a un altro servizio.

Mirroring del traffico di Cloud Service Mesh.
Mirroring del traffico di Cloud Service Mesh (fai clic per ingrandire)

Bilanciamento del carico ottimizzato per le prestazioni

A seconda delle caratteristiche della tua applicazione, potresti scoprire che migliorare le prestazioni e la disponibilità ottimizzando le modalità di distribuzione del traffico nei backend di un servizio. Con Cloud Service Mesh, puoi applicare algoritmi di bilanciamento del carico avanzati in modo che il traffico venga distribuito per soddisfare le tue esigenze.

Il seguente diagramma, a differenza di quelli precedenti, mostra sia una destinazione (servizio di produzione) e i backend per quel servizio di backend (Macchina virtuale 1, Macchina virtuale 2, Macchina virtuale 3). Con gestione avanzata del traffico, puoi configurare il modo in cui un servizio di backend di destinazione e il modo in cui il traffico viene distribuito tra i backend per servizio di destinazione.

Bilanciamento del carico di Cloud Service Mesh.
Bilanciamento del carico di Cloud Service Mesh(fai clic per ingrandire)

Passaggi successivi