Questa pagina mostra dettagli specifici di Cloud Run per gli sviluppatori che vogliono utilizzare gRPC per collegare un servizio Cloud Run ad altri servizi, ad esempio per fornire una comunicazione semplice e ad alte prestazioni tra i microservizi interni. Puoi utilizzare tutti i tipi di gRPC, streaming o unary, con Cloud Run.
Ecco alcuni possibili casi d'uso:
- Comunicazione tra microservizi interni.
- Carichi elevati di dati (gRPC utilizza i buffer di protocollo, che sono fino a sette volte più veloci delle chiamate REST).
- È necessaria solo una semplice definizione di servizio, non devi scrivere una biblioteca client completa.
- Utilizza i gRPC in streaming nel tuo server gRPC per creare applicazioni e API più reattive.
Per integrare il tuo servizio con gRPC:
- Configura il servizio in modo che utilizzi HTTP/2 se utilizzi gRPC in streaming. HTTP/2 è il metodo di trasporto per lo streaming gRPC.
- Definisci i messaggi di richiesta e le risposte in un file proto e compilali.
- Crea un server gRPC per gestire le richieste e restituire le risposte: deve ascoltare la variabile di ambiente
PORT
. - Crea un client che invia richieste e gestisce le risposte del server gRPC.
- Se vuoi, aggiungi l'autenticazione.
- Crea ed esegui il deployment del tuo servizio.
Configurare il servizio per l'utilizzo di HTTP/2
Google consiglia di configurare il servizio in modo che utilizzi HTTP/2 se utilizzi gRPC con Cloud Run. Sebbene alcune semplici funzionalità gRPC funzionino senza utilizzare HTTP/2, molte funzionalità gRPC, come lo streaming e i metadati, richiedono HTTP/2.
Definire e compilare i messaggi in un file proto
Non sono necessari elementi aggiuntivi o specifici di Cloud Run da aggiungere alle definizioni proto. Come per qualsiasi altro utilizzo di gRPC, utilizzi buffer del protocollo gRPC per le definizioni dei servizi e la serializzazione dei dati.
Creazione di un client gRPC
Non sono necessarie aggiunte specifiche per Cloud Run o aggiuntive a un client che utilizza gRPC: segui le indicazioni nelle documentazioni di gRPC sull'utilizzo delle definizioni di servizio nel codice client e i client di esempio forniti nei tutorial gRPC specifici per lingua.
Scalabilità automatica e bilanciamento del carico
Cloud Run utilizza bilanciatori del carico gestiti da Google che mantengono separate le connessioni tra i client e le istanze Cloud Run. Con gRPC, la scalabilità automatica si comporta nel seguente modo:
- Le connessioni gRPC dei client terminano al bilanciatore del carico perimetrale. La modifica delle impostazioni
KeepAlive
influisce solo sulla connessione al bilanciatore del carico, non sulle istanze Cloud Run. Il client non riconosce quando un'istanza viene eliminata. - Durante lo scaling in, il bilanciatore del carico chiude le connessioni inviando messaggi GOAWAY alle istanze di backend durante l'arresto.
- Durante lo scale-out, il bilanciatore del carico crea nuove connessioni alle istanze di backend. Tutte queste operazioni sono trasparenti per i clienti.
- Durante la scalabilità automatica, molte istanze possono essere avviate e multiplexate in una singola connessione tra il client e il bilanciatore del carico proxy.
- La concorrenza è determinata dal numero massimo di richieste in parallelo per istanza per i messaggi. In streaming, ogni stream viene conteggiato una volta rispetto al numero massimo di richieste in parallelo.
Ascolto delle richieste gRPC in un servizio Cloud Run
L'unico requisito speciale per un server gRPC in esecuzione in Cloud Run è ascoltare sulla porta specificata dalla variabile di ambiente PORT
come mostrato nel seguente codice:
Vai
Apertura di una connessione gRPC a un servizio
Per aprire una connessione gRPC a un servizio in modo da poter inviare messaggi gRPC, devi specificare il dominio host, ovvero l'URL del servizio Cloud Run o il dominio personalizzato mappato a quel servizio, insieme alla porta 443, che è la porta che dovrebbe essere utilizzata da gRPC.
Vai
Invio di richieste gRPC senza autenticazione
Il seguente esempio mostra come inviare una richiesta senza autenticazione, utilizzando una connessione gRPC configurata come indicato in precedenza.
Vai
Invio di richieste gRPC con autenticazione
Il seguente esempio mostra come utilizzare l'autenticazione tra servizi, se il servizio chiamante dispone dell'autorizzazione invoker per il servizio di ricezione. Tieni presente che questo codice crea un'intestazione di autorizzazione con il token di identità corretto: questo è obbligatorio. Le autorizzazioni richieste e l'intestazione di autorizzazione sono descritte in dettaglio nell'autenticazione da servizio a servizio.
Vai
Codice di esempio per lo streaming gRPC
Per codice campione, consulta l'implementazione di RouteGuide
nel tutorial di base su gRPC per il linguaggio che preferisci. Ad esempio, se utilizzi Go, consulta
Implementazione di RouteGuide.