Questo documento descrive come modificare un'app Python per raccogliere tracce. e metriche utilizzando il framework open source OpenTelemetry, e come per scrivere log JSON strutturati in uscita standard. Il presente documento fornisce inoltre su un'app Python di esempio che puoi installare ed eseguire. L'app utilizza il framework web Flask ed è configurata per generare metriche, tracce e log.
Per saperne di più sulla strumentazione, consulta i seguenti documenti:
Informazioni sulla misurazione manuale e automatica
Per questa lingua, OpenTelemetry definisce la strumentazione automatica come la pratica di raccogliere dati di telemetria librerie e framework senza apportare modifiche al codice. Tuttavia, puoi installare i moduli e impostare le variabili di ambiente.
Questo documento non descrive la strumentazione automatica. Per informazioni su questo argomento, vedi Strumentazione automatica per Python.
Per informazioni generali, vedi OpenTelemetry Instrumentation per Python.
Prima di iniziare
Enable the Cloud Logging, Cloud Monitoring, and Cloud Trace APIs.
Instrumenta l'app per raccogliere tracce, metriche e log
Per eseguire l'instrumentazione dell'app in modo da raccogliere dati sulle metriche e sulle tracce e scrivere JSON strutturato nello standard out, svolgi i seguenti passaggi come descritto nelle sezioni successive di questo documento:
Configura OpenTelemetry
Questa app di esempio è configurata per utilizzare l'SDK Python OpenTelemetry per esportare tracce e metriche utilizzando il protocollo OTLP. Per impostazione predefinita, l'SDK Python di OpenTelemetry utilizza il formato W3C Trace Context per propagare il contesto traccia, il che garantisce che gli span abbiano la relazione padre-figlio corretta all'interno di una traccia.
Il seguente esempio di codice illustra un modulo Python per configurare OpenTelemetry. Per visualizzare l'esempio completo, fai clic su more_vert Altro e poi seleziona Visualizza su GitHub.
L'app Flask si basa su Gunicorn per gestire le richieste HTTP seguendo i consigli della guida Eseguire il deployment in produzione di Flask.
Gunicorn avvia più copie dell'app in processi di lavoro indipendenti per aumentare il throughput. Per garantire che le metriche dei processi worker non entrino in conflitto tra loro, consigliamo a ogni processo worker di impostare un valore univoco per l'attributo della risorsa service.instance.id
. Un modo per farlo è includere
ID di processo in service.instance.id
. Per ulteriori informazioni, vedi
Collisioni tra serie temporali.
Per ulteriori informazioni e opzioni di configurazione, consulta OpenTelemetry Python dei dati.
Configura il logging strutturato
Per scrivere log strutturati collegati alle tracce, configura l'app in
output di log in formato JSON in output standard con chiavi contenenti traccia
informazioni. Il seguente esempio di codice illustra come configurare lo standard
logging
per generare log strutturati JSON utilizzando
python-json-logger
e come utilizzare
Pacchetto opentelemetry-instrumentation-logging
per includere la traccia
informazioni.
La configurazione precedente estrae le informazioni sull'intervallo attivo dal messaggio di log, quindi aggiunge queste informazioni come attributi al file JSON strutturato 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.
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. La telemetria dell'app viene inoltrata a Google Cloud utilizzando
Collector
OpenTelemetry configurato con gli esportatori Google. Utilizza
Flask per gestire le richieste HTTP e la libreria requests per
effettuare richieste HTTP. Per generare metriche e tracce per il client e il server HTTP, l'app di esempio installa le librerie di ispezione opentelemetry-instrumentation-flask
e opentelemetry-instrumentation-requests
:
L'app ha due endpoint:
L'endpoint
/multi
è gestito dalla funzionemulti
. Il generatore di carico nell'app invia richieste all'endpoint/multi
. Quando questo endpoint riceve una richiesta, invia da tre a sette richieste all'endpoint/single
sul server locale.L'endpoint
/single
è gestito dalla funzionesingle
. Quando questo endpoint riceve una richiesta, dorme per un breve ritardo e poi risponde con una stringa.
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/opentelemetry-operations-python
Vai alla directory di esempio:
cd opentelemetry-operations-python/samples/instrumentation-quickstart
Crea ed esegui il sample:
docker compose up --abort-on-container-exit
Se non stai utilizzando Cloud Shell, esegui l'applicazione con
GOOGLE_APPLICATION_CREDENTIALS
variabile di ambiente che punta a una delle credenziali. Credenziali predefinite dell'applicazione fornisce un file delle credenziali in$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 misurazione OpenTelemetry nell'app di esempio genera metriche Prometheus che puoi visualizzare utilizzando Metrics Explorer:
Prometheus/http_server_duration_milliseconds/histogram
registra la durata delle richieste al server e memorizza i risultati in un istogramma.Prometheus/http_client_duration_milliseconds/histogram
registra la durata delle richieste del client e archivia i risultati in un istogramma.
-
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,
digita
http_server
nella barra dei filtri e 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 per saperne di più, consulta Tipi, tipi e conversioni.
Quando vengono misurati valori interi o doppi, ad esempio con i due valori
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:
-
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
.Si apre un riquadro che mostra informazioni sulla richiesta HTTP. Questi dettagli includono il metodo, il codice di stato, il numero di byte e l'agente utente del chiamante.
Per visualizzare i log associati a questa traccia, seleziona Log e Eventi.
La scheda mostra i singoli log. Per visualizzare i dettagli della voce di log, espandere la voce di log. Puoi anche fare clic su Visualizza log e visualizzare il log utilizzando Esplora log.
Per ulteriori informazioni sull'utilizzo di Explorer di Cloud Trace, 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
handle /multi request
.Per visualizzare i dettagli del log, espandi la voce del log.
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 traccia 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
- Risolvi i problemi di Cloud Trace