Questo documento descrive come modificare un'app Go per raccogliere tracce e dati delle metriche utilizzando il framework open source OpenTelemetry e come e scrivere log JSON strutturati su "Standard-out". Il presente documento fornisce inoltre le informazioni su un'app di esempio che puoi installare ed eseguire. La è configurata per generare metriche, tracce e log.
Per saperne di più sulla strumentazione, consulta i seguenti documenti:
Informazioni sul contesto
Il contesto di OpenTelemetry è un meccanismo per trasportare valori basati sull'ambito di esecuzione tra le API all'interno di un processo. Un uso importante del contesto è quello di intervallo attivo corrente in modo che possa essere modificato o indicato come padre di qualsiasi i nuovi intervalli al momento della creazione. In sintesi:
Per contesto si intende il meccanismo per propagare i valori basati sull'ambito di esecuzione, incluso l'intervallo attivo corrente, tra le API all'interno di un processo.
Contesto span è un oggetto immutabile in ogni span che include l'ID traccia, l'ID span, i flag e lo stato della traccia.
La propagazione è il meccanismo che sposta il contesto tra servizi e processi.
context.Context
della libreria standard di Go trasporta anche i valori con ambito tra i confini delle API. Di solito, le funzioni gestore in un server
un Context
in arrivo e passarlo attraverso la catena di chiamate a qualsiasi
per i clienti che effettuano richieste in uscita.
La libreria standard di Go context.Context
viene utilizzata come implementazione del contesto OpenTelemetry in Go.
Prima di iniziare
Enable the Cloud Logging, Cloud Monitoring, and Cloud Trace APIs.
Instrumenta l'app per raccogliere tracce, metriche e log
Per instrumentare l'app in modo che raccolga dati relativi a tracce e metriche e per scrivere da JSON strutturato a Standard Out, esegui i seguenti passaggi come descritto nelle sezioni successive del presente documento:
- Configurare la funzione principale
- Configurare OpenTelemetry
- Configurare il logging strutturato
- Aggiungere la misurazione al server HTTP
- Collega intervalli di tracce con log e metriche
- Aggiungere la strumentazione al client HTTP
- Scrivere log strutturati
Configura la funzione principale
Per configurare l'app in modo che scriva log strutturati e raccolga metriche e dati traccia utilizzando OpenTelemetry, aggiorna la funzione main
per configurare il pacchetto di logging strutturato di Go, slog
, e per configurare OpenTelemetry.
Il seguente esempio di codice illustra una funzione main
che chiama due funzioni di supporto, setupLogging()
e setupOpenTelemetry()
. Queste funzioni di supporto configurano il pacchetto di logging e OpenTelemetry.
Per visualizzare l'anteprima completa, fai clic su more_vert Altro, quindi seleziona Visualizza su GitHub.
Dopo aver configurato il pacchetto di logging, collega i log alla traccia
devi passare il comando Go Context
al logger. Per ulteriori informazioni,
consulta la sezione Scrivere log strutturati della presente documentazione
documento.
Configurare OpenTelemetry
Per raccogliere ed esportare tracce e metriche utilizzando il protocollo OTLP, configura le istanze TracerProvider
e MeterProvider
globali.
Il seguente esempio di codice illustra la funzione setupOpenTelemetry
,
che viene chiamata dalla funzione main
:
Il precedente esempio di codice configura TextMapPropagator
globale in modo da utilizzare il formato W3C Trace Context per propagare il contesto traccia. Questa configurazione garantisce che gli intervalli abbiano la relazione padre-figlio corretta all'interno di una traccia.
Per garantire che tutti i dati di telemetria in sospeso siano stati eliminati e che le connessioni siano chiuse
controllata, la funzione setupOpenTelemetry
restituisce una funzione denominata
shutdown
, che esegue queste azioni.
Configura il logging strutturato
Per includere le informazioni sulla traccia all'interno dei log in formato JSON scritti
nella standard output, configura il pacchetto di logging strutturato Go, slog
.
Il seguente esempio di codice illustra la funzione setupLogging
:
che viene richiamata dalla funzione main
:
Il codice precedente chiama la funzione handlerWithSpanContext
, che estrae informazioni dall'istanza Context
e le aggiunge come attributi a un log. Questi attributi possono quindi essere utilizzati per correlare un log a una traccia:
logging.googleapis.com/trace
: nome della risorsa della traccia associata alla voce di log.logging.googleapis.com/spanId
: l'ID intervallo con la traccia che è associati alla voce di log.logging.googleapis.com/trace_sampled
: il valore di questo campo deve esseretrue
ofalse
.
Per saperne di più su questi campi, consulta la LogEntry
alla struttura del centro di costo.
Aggiungi la misurazione al server HTTP
Per aggiungere strumentazione traccia e metrica alle richieste gestite dal
utilizzare OpenTelemetry. Nell'esempio seguente viene utilizzato il gestore otelhttp
per propagare il contesto e per la strumentazione di tracce e metriche:
Nel codice precedente, l'handler otelhttp
utilizza le istanze globali TracerProvider
, MeterProvider
e TextMapPropagator
. La
La funzione setupOpenTelemetry
configura queste istanze.
Collega gli intervalli di traccia con log e metriche
Per collegare gli intervalli del server e del client e associare metriche e log, passa l'istanza Go Context
alla richiesta HTTP e quando scrivi i log.
L'esempio seguente mostra un gestore di route che estrae l'istanza Context
di Go e la passa al logger e alla funzione callSingle
, che effettua una richiesta HTTP in uscita:
Nel codice precedente, la chiamata di funzione r.Context()
recupera il valore Go Context
dalla richiesta HTTP.
Aggiungere la misurazione al client HTTP
a inserire il contesto della traccia nelle richieste HTTP in uscita e aggiungere
traccia e strumentazione metrica, chiama la funzione otelhttp.Get
.
Nell'esempio seguente, la funzione callSingle
esegue questa azione:
Nel codice precedente, il gestore otelhttp
utilizza il campo
Istanze TracerProvider
, MeterProvider
e TextMapPropagator
. La
La funzione setupOpenTelemetry
configura queste istanze.
Scrittura di log strutturati
Per scrivere log strutturati che rimandano a una traccia, utilizza il pacchetto di logging strutturato di Go, slog
, e passa l'istanza Context
di Go al logger.
L'istanza Go Context
è necessaria quando vuoi collegare un log a un intervallo.
Ad esempio, la seguente istruzione mostra come chiamare l'elemento InfoContext
per slog
e spiega come aggiungere il campo subRequests
all'istanza JSON:
slog.InfoContext(r.Context(), "handle /multi request", slog.Int("subRequests", subRequests))
Esegui un'app di esempio configurata per raccogliere la telemetria
L'app di esempio utilizza formati indipendenti dal fornitore, tra cui JSON per i log e OTLP
per ottenere metriche e tracce. Per instradare la telemetria a Google Cloud, questo esempio utilizza
OpenTelemetry Collector
configurato con gli esportatori Google. Il generatore di carico
inviata all'app invia richieste ai percorsi dell'app.
Scarica ed esegui il deployment dell'app
Per eseguire l'esempio, segui questi passaggi:
-
In the Google Cloud console, activate Cloud Shell.
At the bottom of the Google Cloud console, a Cloud Shell session starts and displays a command-line prompt. Cloud Shell is a shell environment with the Google Cloud CLI already installed and with values already set for your current project. It can take a few seconds for the session to initialize.
Clona il repository:
git clone https://github.com/GoogleCloudPlatform/golang-samples
Vai alla directory OpenTelemetry:
cd golang-samples/opentelemetry/instrumentation
Crea ed esegui il sample:
docker compose up --abort-on-container-exit
Se non esegui l'applicazione su Cloud Shell, eseguila con la variabile di ambiente
GOOGLE_APPLICATION_CREDENTIALS
che rimanda a un file delle credenziali. App predefinita Credenziali fornisce un file di credenziali all'indirizzo$HOME/.config/gcloud/application_default_credentials.json
.# Set environment variables export GOOGLE_CLOUD_PROJECT="PROJECT_ID" export GOOGLE_APPLICATION_CREDENTIALS="$HOME/.config/gcloud/application_default_credentials.json" export USERID="$(id -u)" # Run docker compose -f docker-compose.yaml -f docker-compose.creds.yaml up --abort-on-container-exit
Visualizzare le metriche
La strumentazione OpenTelemetry nell'app di esempio genera Prometheus che puoi visualizzare utilizzando Esplora metriche:
Prometheus/http_server_duration/histogram
registra la durata delle richieste del server e archivia i risultati in un istogramma.Prometheus/http_server_request_content_length_total/counter
registra la lunghezza dei contenuti della richiesta per/multi
e/single
route HTTP. Le misurazioni di questa metrica sono cumulative, il che significa che ogni valore rappresenta il totale dall'inizio della raccolta dei valori.Prometheus/http_server_response_content_length_total/counter
registra la durata dei contenuti della risposta per le route HTTP/multi
e/single
. Le misurazioni di questa metrica sono cumulative.
-
Nella console Google Cloud, vai alla pagina leaderboard Esplora metriche:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Monitoring.
- Nell'elemento Metrica, espandi il menu Seleziona una metrica,
inserisci
http_server
nella barra dei filtri, poi utilizza i sottomenu per selezionare un tipo di risorsa e una metrica specifici:- Nel menu Risorse attive, seleziona Destinazione Prometheus.
- Nel menu Categorie di metriche attive, seleziona Http.
- Nel menu Metriche attive, seleziona una metrica.
- Fai clic su Applica.
- Configura la modalità di visualizzazione dei dati.
Quando le misurazioni di una metrica sono cumulativi, Metrics Explorer normalizza automaticamente i dati misurati il periodo di allineamento, che determina la visualizzazione di un tasso nel grafico. Per maggiori informazioni, consulta Tipi, conversioni e tipi.
Quando vengono misurati valori interi o doppi, ad esempio con le due metriche
counter
, Metrics Explorer somma automaticamente tutte le serie temporali. Per visualizzare i dati per le route HTTP/multi
e/single
, imposta il primo menu della voce Aggregazione su Nessuna.Per ulteriori informazioni sulla configurazione di un grafico, consulta Seleziona le metriche quando utilizzi Esplora metriche.
Visualizza le tue tracce
Per visualizzare i dati di traccia, segui questi passaggi:
-
Nella console Google Cloud, vai alla pagina Esplora tracce.
Puoi trovare questa pagina anche utilizzando la barra di ricerca.
- Nel grafico a dispersione, seleziona una traccia con l'URI
/multi
. Nel grafico di Gantt nel riquadro Dettagli su Trace, seleziona l'intervallo contrassegnato come
/multi
.Viene visualizzato un riquadro che mostra le informazioni sulla richiesta HTTP. Questi tra cui metodo, codice di stato, numero di byte e e lo user agent del chiamante.
Per visualizzare i log associati a questa traccia, seleziona la scheda Log ed eventi.
La scheda mostra i singoli log. Per visualizzare i dettagli della voce di log, espandila. Puoi anche fare clic su Visualizza log e visualizzare il log utilizzando Esplora log.
Per ulteriori informazioni sull'utilizzo di Trace Explorer, consulta Trovare ed esplorare le tracce.
Visualizza i log
Da Esplora log, puoi ispezionare i log e anche visualizzare le tracce associate, se esistono.
-
Nella console Google Cloud, vai alla pagina Esplora log:
Se utilizzi la barra di ricerca per trovare questa pagina, seleziona il risultato con il sottotitolo Logging.
Individua un log con la descrizione di
handle /multi request
.Per visualizzare i dettagli del log, espandi la voce di log. Nel campo
jsonPayload
è presente una voce denominatasubRequests
. Questa voce è stata aggiunta da un'istruzione nella funzionehandleMulti
.Fai clic su Tracce in una voce di log con il messaggio "handle /multi request", quindi seleziona Visualizza dettagli traccia.
Si apre un riquadro Dettagli su Trace che mostra la traccia selezionata.
Per ulteriori informazioni sull'uso di Esplora log, consulta Visualizza i log utilizzando Esplora log.
Passaggi successivi
- OpenTelemetry
- Specifiche OTLP
- Logging strutturato
- Risoluzione dei problemi di Managed Service per Prometheus
- Risolvere i problemi di Cloud Trace