Questo documento descrive come modificare un'app Java per raccogliere dati di traccia e metriche utilizzando il framework open source OpenTelemetry e come scrivere log JSON strutturati in standard out. Questo documento fornisce anche informazioni su un'app Java Spring Boot di esempio che puoi installare ed eseguire. L'app è configurata per generare metriche, tracce e log. I passaggi sono gli stessi indipendentemente dal fatto che tu stia utilizzando o meno Spring Boot Framework.
Per saperne di più sulla strumentazione, consulta i seguenti documenti:
Informazioni sulla strumentazione manuale e senza codice
La strumentazione descritta in questo documento si basa sulla strumentazione zero-code di OpenTelemetry per inviare la telemetria al tuo progetto Google Cloud . Per Java, la strumentazione zero-code si riferisce alla pratica di inserire dinamicamente bytecode in librerie e framework per acquisire la telemetria. L'instrumentazione senza codice può raccogliere dati di telemetria per elementi come chiamate HTTP in entrata e in uscita. Per maggiori informazioni, vedi Agente Java.
OpenTelemetry fornisce anche un'API per aggiungere l'instrumentazione personalizzata al tuo codice. OpenTelemetry si riferisce a questa procedura come strumentazione manuale. Questo documento non descrive la strumentazione manuale. Per esempi e informazioni su questo argomento, consulta Strumentazione manuale.
Prima di iniziare
Enable the Cloud Logging, Cloud Monitoring, and Cloud Trace APIs.
Instrumenta la tua app per raccogliere tracce, metriche e log
Per instrumentare l'app in modo da raccogliere dati di traccia e metriche e scrivere JSON strutturato in standard out, segui i passaggi descritti nelle sezioni successive di questo documento:
- Configurare l'app per utilizzare l'agente Java OpenTelemetry
- Configurare OpenTelemetry
- Configurare il logging strutturato
- Scrivere log strutturati
Configura la tua app per utilizzare l'agente Java OpenTelemetry
Per configurare l'app in modo che scriva log strutturati e raccolga metriche e dati di traccia utilizzando OpenTelemetry, aggiorna la chiamata dell'app in modo che utilizzi OpenTelemetry Java Agent. Questo metodo di strumentazione dell'app è noto come strumentazione automatica perché non richiede la modifica del codice dell'app.
Il seguente esempio di codice illustra un Dockerfile che scarica il file JAR dell'agente Java OpenTelemetry e aggiorna l'invocazione della riga di comando per passare il flag -javaagent
.
Per visualizzare l'esempio completo, fai clic su more_vert Altro e poi seleziona Visualizza su GitHub.
In alternativa, puoi anche impostare il flag -javaagent
nella variabile di ambiente JAVA_TOOL_OPTIONS
:
export JAVA_TOOL_OPTIONS="-javaagent:PATH/TO/opentelemetry-javaagent.jar"
Configura OpenTelemetry
La configurazione predefinita per l'agente Java OpenTelemetry esporta tracce e metriche utilizzando il protocollo OTLP. Inoltre, configura OpenTelemetry per utilizzare il formato W3C Trace Context per la propagazione del contesto di traccia. Questa configurazione garantisce che gli intervalli abbiano la corretta relazione padre-figlio all'interno di una traccia.
Per ulteriori informazioni e opzioni di configurazione, consulta Strumentazione automatica OpenTelemetry Java.
Configura il logging strutturato
Per includere le informazioni di traccia nei log in formato JSON scritti nell'output standard, configura l'app in modo che restituisca log strutturati in formato JSON. Ti consigliamo di utilizzare Log4j2 come implementazione della registrazione.
Il seguente esempio di codice mostra un file log4j2.xml
configurato per l'output
di log strutturati JSON utilizzando il layout del modello JSON:
La configurazione precedente estrae le informazioni sullo span attivo dal contesto diagnostico mappato di SLF4J e le aggiunge come attributi al log. Questi attributi possono essere utilizzati per correlare un log a una traccia:
logging.googleapis.com/trace
: il nome della risorsa della traccia associata alla voce di log.logging.googleapis.com/spanId
: l'ID intervallo con la traccia associata alla voce di log.logging.googleapis.com/trace_sampled
: il valore di questo campo deve esseretrue
ofalse
.
Per ulteriori informazioni su questi campi, consulta la struttura LogEntry
.
Scrittura di log strutturati
Per scrivere log strutturati che rimandano a una traccia, utilizza l'API di logging SLF4J. Ad esempio, la seguente istruzione mostra come chiamare il metodo Logger.info()
:
logger.info("handle /multi request with subRequests={}", subRequests);
L'agente Java OpenTelemetry compila automaticamente il contesto diagnostico mappato di SLF4J con il contesto dello span dello span attivo corrente nel contesto OpenTelemetry. Il contesto diagnostico mappato viene quindi incluso nei log JSON come descritto in Configurare la registrazione strutturata.
Esegui un'app di esempio configurata per raccogliere dati di telemetria
L'app di esempio utilizza formati indipendenti dal fornitore, tra cui JSON per i log e OTLP
per metriche e tracce, e il framework Spring Boot. Per indirizzare
la telemetria a Google Cloud, questo esempio utilizza OpenTelemetry Collector
configurato con gli esportatori Google. L'app ha due endpoint:
L'endpoint
/multi
viene gestito dalla funzionehandleMulti
. 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
viene gestito dalla funzionehandleSingle
. Quando questo endpoint riceve una richiesta, rimane inattivo per un breve periodo e poi risponde con una stringa.
Scaricare ed eseguire il deployment dell'app
Per eseguire l'esempio:
-
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-java
Vai alla directory di esempio:
cd opentelemetry-operations-java/examples/instrumentation-quickstart
Crea ed esegui il campione:
docker compose up --abort-on-container-exit
Se non esegui l'applicazione su Cloud Shell, esegui l'applicazione con la variabile di ambiente
GOOGLE_APPLICATION_CREDENTIALS
che punta a un file delle credenziali. Credenziali predefinite dell'applicazione fornisce un file di 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
L'instrumentazione OpenTelemetry nell'app di esempio genera metriche Prometheus che puoi visualizzare utilizzando Esplora metriche:
Prometheus/http_server_duration_milliseconds/histogram
registra la durata delle richieste del server e memorizza i risultati in un istogramma.Prometheus/http_client_duration_milliseconds/histogram
registra la durata delle richieste client e memorizza 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.
- Nella barra degli strumenti della console Google Cloud , seleziona il tuo Google Cloud progetto. Per le configurazioni di App Hub, seleziona il progetto host di App Hub o il progetto di gestione della cartella app.
- 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 cumulative, Metrics Explorer normalizza automaticamente i dati misurati in base al periodo di allineamento, il che comporta la visualizzazione di una frequenza nel grafico. Per maggiori informazioni, consulta Tipi, tipi e conversioni.
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 durante l'utilizzo di Esplora metriche.
Visualizzare le tracce
Potrebbero essere necessari diversi minuti prima che i dati di tracciamento siano disponibili. Ad esempio, quando i dati di traccia vengono ricevuti dal tuo progetto, Google Cloud Observability potrebbe dover creare un database per archiviarli. La creazione del database può richiedere alcuni minuti e durante questo periodo non sono disponibili dati di traccia da visualizzare.
Per visualizzare i dati di traccia:
-
Nella Google Cloud console, vai alla pagina Esplora tracce:
Puoi trovare questa pagina anche utilizzando la barra di ricerca.
- Nella sezione della tabella della pagina, seleziona una riga con il nome dello span
/multi
. Nel grafico di Gantt nel riquadro Dettagli su Trace, seleziona l'intervallo etichettato
/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 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 Esplora tracce, consulta Trovare ed esplorare le tracce.
Visualizza i log
Da Esplora log puoi esaminare i log e visualizzare le tracce associate, se esistenti.
-
Nella Google Cloud console, 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.
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.
I dati di log potrebbero essere disponibili diversi minuti prima dei dati di traccia. Se si verifica un errore durante la visualizzazione dei dati di traccia cercando una traccia per ID o seguendo i passaggi descritti in questa attività, attendi un minuto o due e riprova.
Per saperne di più sull'utilizzo di Esplora log, consulta Visualizzare i log utilizzando Esplora log.
Passaggi successivi
- OpenTelemetry
- Specifica OTLP
- Logging strutturato
- Risoluzione dei problemi di Managed Service per Prometheus
- Risoluzione dei problemi di Cloud Trace