Il monitoraggio OpenTelemetry ti consente di identificare e monitorare la latenza di varie operazioni della libreria client Pub/Sub, come il raggruppamento, la gestione dei lease e il controllo del flusso. La raccolta di queste informazioni può aiutarti a eseguire il debug di problemi relativi alla libreria client.
Ecco alcuni potenziali casi d'uso per il monitoraggio di OpenTelemetry:
- Il tuo servizio sta riscontrando una latenza di pubblicazione superiore al normale.
- Stai riscontrando un numero elevato di riesecuzioni di messaggi.
- Una modifica alla funzione di callback del client dell'abbonato fa sì che l'elaborazione impieghi più tempo del solito.
Prima di iniziare
Prima di configurare OpenTelemetry, completa le seguenti attività:
- Configura Pub/Sub utilizzando una delle librerie client.
- Installa l'SDK OpenTelemetry e configura un esportatore di traccia e un provider di tracer.
- Abilita l'API Cloud Trace.
- Scopri come leggere le tracce di Cloud Observability.
Ruoli obbligatori
Per assicurarti che l'account di servizio disponga delle autorizzazioni necessarie per esportare le tracce in Cloud Trace, chiedi all'amministratore di concedere all'account di servizio i seguenti ruoli IAM nel progetto:
-
Tutti:
Agente Cloud Trace (
roles/cloudtrace.agent
)
Per saperne di più sulla concessione dei ruoli, consulta Gestire l'accesso a progetti, cartelle e organizzazioni.
Questi ruoli predefiniti contengono le autorizzazioni necessarie per esportare le tracce in Cloud Trace. Per visualizzare le autorizzazioni esatte richieste, espandi la sezione Autorizzazioni richieste:
Autorizzazioni obbligatorie
Per esportare le tracce in Cloud Trace sono necessarie le seguenti autorizzazioni:
-
Tutti:
cloudtrace.traces.patch
L'amministratore potrebbe anche assegnare all'account di servizio queste autorizzazioni con ruoli personalizzati o altri ruoli predefiniti.
Flusso di lavoro di monitoraggio di OpenTelemetry
Per configurare il monitoraggio OpenTelemetry, utilizza le librerie client Pub/Sub e l'SDK OpenTelemetry. Con l'SDK, devi configurare un esportatore di traccia e un provider di traccianti prima di connetterti alle librerie Pub/Sub. In alcune librerie, la configurazione di un fornitore di tracker è facoltativa.
Esportatore di trace. L'SDK OpenTelemetry utilizza l'esportatore di tracce per determinare dove inviare le tracce.
Fornitore di tracker. Le librerie client Pub/Sub utilizzano il fornitore di tracer per creare tracce.
I passaggi riportati di seguito descrivono come configurare il monitoraggio:
- Crea un'istanza di un esportatore OpenTelemetry di Cloud Trace.
- Se necessario, crea un'istanza e registra un provider di tracker utilizzando l'SDK OpenTelemetery.
- Configura il client con l'opzione di attivazione del monitoraggio OpenTelemetry.
- Utilizza le librerie client Pub/Sub per pubblicare un messaggio.
Come funziona il monitoraggio
Per ogni messaggio pubblicato, la libreria client crea una nuova traccia. Questa traccia rappresenta l'intero ciclo di vita del messaggio, dal momento in cui lo pubblichi fino a quando non viene confermato. Una traccia incapsula informazioni come la durata delle operazioni, gli span principali e secondari e gli span collegati.
Una traccia è composta da uno elemento principale e dagli elementi secondari corrispondenti. Questi intervalli rappresentano il lavoro svolto dalla libreria client durante l'elaborazione di un messaggio. Ogni traccia del messaggio contiene quanto segue:
- Per la pubblicazione. Controllo flusso, pianificazione delle chiavi di ordinamento, raggruppamento e la durata dell'RPC di pubblicazione.
- Per gli abbonamenti. Controllo della concorrenza, pianificazione delle chiavi di ordinamento e gestione dei lease.
Per propagare le informazioni dal lato di pubblicazione a quello di sottoscrizione, le librerie client iniettano un attributo specifico di monitoraggio sul lato di pubblicazione. Il meccanismo di propagazione del contesto viene attivato solo quando il monitoraggio è attivo e viene anteposto il prefisso googclient_
.
Pubblicare messaggi con il monitoraggio
Il seguente esempio di codice mostra come attivare il monitoraggio utilizzando la libreria client Pub/Sub e l'SDK OpenTelemetry. In questo esempio, i risultati del monitoraggio vengono esportati in Cloud Trace.
Considerazioni
Quando esegui l'inizializzazione del provider di tracer, configuri un rapporto di campionamento con l'SDK OpenTelemetry. Questo rapporto determina quante tracce deve campionare l'SDK. Una frequenza di campionamento più bassa può contribuire a ridurre i costi di fatturazione e impedire al tuo servizio di superare la quota degli intervalli di Cloud Trace.
Vai
C++
Python
Prima di provare questo esempio, segui le istruzioni di configurazione di Python riportate nella guida rapida all'utilizzo delle librerie client. Per ulteriori informazioni, consulta la documentazione di riferimento dell'API Pub/Sub per Python.
TypeScript
Node.js
Java
Ricevere messaggi con il monitoraggio
Vai
C++
Python
TypeScript
Node.js
Java
Analizzare una traccia
Le sezioni che seguono contengono informazioni dettagliate su come monitorare e analizzare una traccia nella console Google Cloud.
Considerazioni
- Quando pubblichi un batch di messaggi, l'intervallo RPC di pubblicazione viene acquisito in una traccia distinta.
- Un'RPC di pubblicazione ha più intervalli di origine, poiché più chiamate create possono generare un'RPC di pubblicazione quando vengono raggruppate.
Gli span in OpenTelemetry possono avere zero o un span principale.
Gli elementi che rappresentano operazioni raggruppate, come un batch di pubblicazione, (che logicamente dovrebbe avere più elementi principali) non possono essere rappresentati utilizzando zero o un elemento principale.
Monitorare gli intervalli creati durante il ciclo di vita del messaggio
L'immagine seguente mostra un esempio di span creati in una singola traccia per un singolo messaggio.
Ogni intervallo può avere attributi aggiuntivi che forniscono informazioni aggiuntive, ad esempio la dimensione in byte del messaggio e le informazioni chiave per l'ordinamento.
Gli attributi span trasmettono metadati aggiuntivi, come la chiave di ordinamento del messaggio, l'ID messaggio e le dimensioni del messaggio.
Gli intervalli di pubblicazione e sottoscrizione principali sono integrati con eventi di intervallo che corrispondono al momento in cui viene emessa una chiamata di rete e al momento in cui viene completata.
Risolvere i problemi più comuni
I seguenti problemi possono causare problemi di monitoraggio:
- L'account di servizio che utilizzi per esportare le tracce non ha il ruolo
roles/cloudtrace.agent
richiesto. - È stata raggiunta la quota del numero massimo di span importati in Cloud Trace.
- L'applicazione viene terminata senza chiamare la funzione di svuotamento appropriata.