Se utilizzi Pub/Sub per pubblicare messaggi che generano una grande quantità di dati, puoi utilizzare gRPC per comprimere i dati e risparmiare sui costi di rete prima che il client publisher invii la richiesta di pubblicazione. La compressione Pub/Sub per gRPC utilizza l'algoritmo Gzip.
Questo documento fornisce informazioni sulla compressione dei messaggi pubblicati in un argomento.
Informazioni sulla compressione dei messaggi
Il tasso di compressione per l'utilizzo della funzionalità di compressione lato client gRPC è diverso per i diversi client publisher e dipende dai seguenti fattori:
Quantità di dati. Il rapporto di compressione migliora quando le dimensioni del payload aumentano da poche centinaia di byte a molti kilobyte di dati. Le impostazioni del batch di una richiesta di pubblicazione determinano la quantità di dati inclusi in ogni richiesta di pubblicazione. Per ottenere risultati ottimali, ti consigliamo di attivare le impostazioni batch in combinazione con la compressione gRPC.
Tipo di dati. I dati basati su testo come JSON o XML sono più comprimibili rispetto ai dati binari come le immagini.
Se il tuo client publisher utilizza Google Cloud, puoi utilizzare
la metrica Byte inviati (instance/network/sent_bytes_count
)
per misurare la velocità effettiva di pubblicazione in byte. Se il client
dell'editore si trova su un'altra applicazione, devi utilizzare gli strumenti specifici del client per eseguire la misurazione.
L'esempio di codice in questa sezione mostra un esempio di snippet di codice della libreria client Java che include anche la compressione gRPC.
Prima di iniziare
Prima di configurare il flusso di lavoro di pubblicazione, assicurati di aver completato le seguenti attività:
- Scopri di più sugli argomenti e sul flusso di lavoro di pubblicazione.
- Crea un argomento.
Ruoli obbligatori
Per ottenere le autorizzazioni necessarie per comprimere i messaggi, chiedi all'amministratore di concederti il ruolo IAM Publisher Pub/Sub (roles/pubsub.publisher
) nell'argomento.
Per saperne di più sulla concessione dei ruoli, consulta Gestisci l'accesso a progetti, cartelle e organizzazioni.
Potresti anche riuscire a ottenere le autorizzazioni richieste tramite i ruoli personalizzati o altri ruoli predefiniti.
Per creare o aggiornare argomenti e abbonamenti, devi disporre di autorizzazioni aggiuntive.
Comprimere un messaggio
C++
Prima di provare questo esempio, segui le istruzioni di configurazione di C++ nella guida rapida all'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API Pub/Sub C++.
Java
Prima di provare questo esempio, segui le istruzioni di configurazione di Java nella Guida rapida all'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API Java di Pub/Sub.
Passaggi successivi
Per scoprire come configurare le opzioni di pubblicazione avanzate, consulta quanto segue: