Panoramica delle mappe di regole di routing

Questo documento riguarda solo Cloud Service Mesh con le API di bilanciamento del carico. Ti consigliamo vivamente di utilizzare le API di routing dei servizi.

Una mappa di regole di routing è costituita da quanto segue:

Quando crei e configuri queste risorse per Cloud Service Mesh, Cloud Service Mesh utilizza i valori per creare la configurazione che invia al piano dati, che include i client xDS come i proxy Envoy e le applicazioni gRPC senza proxy. Il piano dati gestisce quindi il traffico in base a questa configurazione.

Una regola di forwarding fa riferimento a un proxy di destinazione e ha un indirizzo IP e una porta. Per i deployment di Cloud Service Mesh, lo schema di bilanciamento del carico della regola di forwarding deve essere impostato su INTERNAL_SELF_MANAGED. Il proxy di destinazione, a sua volta, fa riferimento a una mappa URL. Queste tre risorse si combinano per formare una mappa di regole di routing.

Una regola di forwarding che fa riferimento a un proxy gRPC di destinazione con il campo validateForProxyless impostato su TRUE deve avere l'indirizzo IP impostato su 0.0.0.0. Se il criterio validateForProxyless viene impostato su TRUE, le configurazioni che specificano un indirizzo IP diverso da 0.0.0.0 vengono rifiutate.

La mappa di regole di routing definisce la modalità di trasferimento del traffico dai client ai server all'interno di un mesh di servizi.

Tipi di proxy di destinazione supportati

Cloud Service Mesh supporta i seguenti tipi di proxy di destinazione:

  • Proxy HTTP di destinazione, che viene configurato quando i client e i server inviano o ricevono traffico HTTP o HTTP/2.
  • Proxy HTTPS di destinazione, che viene configurato quando i client e i server inviano o ricevono traffico HTTPS. Questa operazione è necessaria quando configuri la sicurezza dei servizi con i proxy Envoy.
  • Proxy TCP di destinazione, che configuri quando i client e i server inviano o ricevono traffico TCP.
  • Proxy gRPC di destinazione, da configurare quando i client e i server inviano o ricevono traffico gRPC. I proxy gRPC di destinazione contengono il campo validateForProxyless, che è impostato su TRUE quando esegui il deployment di servizi gRPC senza proxy.

Routing del traffico con proxy sidecar Envoy

Quando utilizzi Cloud Service Mesh con proxy sidecar di Envoy, le richieste dei client vengono instradate come segue:

  • Lo stack di rete intercetta la richiesta e la reindirizza al tuo proxy sidecar Envoy.
  • Il proxy sidecar di Envoy controlla l'indirizzo IP e la porta della richiesta.
  • La coppia di indirizzo IP e porta viene verificata in base all'indirizzo IP e alla porta specificati in tutte le regole di forwarding per cui lo schema di bilanciamento del carico è impostato su INTERNAL_SELF_MANAGED.
  • Se viene trovata una regola di forwarding con indirizzo IP e porta corrispondenti, Envoy controlla il proxy HTTP di destinazione o il proxy gRPC di destinazione a cui fa riferimento la regola di forwarding.
  • Envoy controlla la mappa URL a cui fa riferimento il proxy di destinazione.
  • Envoy instrada la richiesta in base alle regole specificate nella mappa URL.

Per informazioni su come il traffico viene instradato con un proxy TCP di destinazione, consulta Routing del traffico TCP con Cloud Service Mesh.

Routing del traffico con applicazioni gRPC senza proxy

Questo comportamento è diverso per le applicazioni gRPC senza proxy. Quando configuri un client gRPC, specifichi l'URI di destinazione per il servizio che il client deve contattare. Questo URI utilizza lo schema resolver del nome xds e il formato hostname:port, ad esempio xds:///example.hostname:8080.

Quando il client gRPC senza proxy si connette a Cloud Service Mesh, Cloud Service Mesh le invia le informazioni corrispondenti al servizio come segue:

  • Cloud Service Mesh cerca le regole di forwarding con schema di bilanciamento del carico impostato su INTERNAL_SELF_MANAGED per trovare regole di forwarding la cui porta corrisponda alla porta specificata nell'URI di destinazione.
  • Cloud Service Mesh trova il proxy gRPC di destinazione o il proxy HTTP di destinazione per ciascuna di queste regole di forwarding.
  • Cloud Service Mesh trova le mappe URL a cui fanno riferimento questi proxy gRPC di destinazione o proxy HTTP di destinazione.
  • Cloud Service Mesh controlla le regole host nella mappa URL, che hanno anche il formato hostname[:port], e cerca una corrispondenza.
  • Quando viene trovata una corrispondenza, Cloud Service Mesh restituisce le regole di routing e le informazioni sul servizio al client gRPC.

Se viene trovata più di una corrispondenza, il comportamento non è definito e può portare a comportamenti imprevedibili. Ciò si verifica in genere quando entrambe le seguenti condizioni sono soddisfatte:

  • Lo stesso nome host viene utilizzato in più mappe URL.
  • Più regole di forwarding con lo schema di bilanciamento del carico INTERNAL_SELF_MANAGED specificano la stessa porta.

Per questo motivo, ti consigliamo di non riutilizzare lo stesso nome host in più mappe URL a cui fanno riferimento regole di forwarding che specificano la stessa porta.

Passaggi successivi