Questo documento descrive come modificare un'app JavaScript Node.js per raccogliere dati su tracce e metriche utilizzando il framework open source OpenTelemetry e come scrivere log JSON strutturati nello standard out. Questo documento fornisce anche informazioni su un'app Node.js di esempio che puoi installare ed eseguire. L'app utilizza il framework web Fastify ed è configurato per generare metriche, per le tracce e i log.
Per scoprire di più sulla misurazione, 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 misurazione automatica. Per informazioni su questo argomento, vedi Strumentazione automatica per il nodo.
Per informazioni generali, vedi OpenTelemetry Instrumentation per nodo.
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 OpenTelemetry
- Configurare l'app per precaricare la configurazione di OpenTelemetry
- Configurare il logging strutturato
- Scrivere log strutturati
Configura OpenTelemetry
La configurazione predefinita per l'SDK OpenTelemetry Node.js esporta le tracce utilizzando il protocollo OTLP. Inoltre, configura OpenTelemetry per l'utilizzo del protocollo W3C Formato del contesto traccia per la propagazione della traccia contesto. Questa configurazione garantisce che gli intervalli abbiano la relazione padre-figlio corretta all'interno di una traccia.
Il seguente esempio di codice illustra un modulo JavaScript per configurare OpenTelemetry.
Per visualizzare l'anteprima completa, fai clic su more_vert Altro, quindi seleziona Visualizza su GitHub.
Il codice di esempio precedente configura OpenTelemetry per esportare le metriche utilizzando il protocollo OTLP e utilizza il pacchetto @opentelemetry/auto-instrumentations-node
per configurare tutte le misurazioni Node.js disponibili.
Per garantire che tutti i dati di telemetria in sospeso siano stati eliminati e che le connessioni siano chiuse
controllato prima dell'arresto dell'applicazione, il gestore SIGTERM
chiama
shutdown
.
Per ulteriori informazioni e opzioni di configurazione, vedi OpenTelemetry Node.js automatico dei dati.
Configura l'app per precaricare la configurazione OpenTelemetry
Per configurare l'app in modo che scriva log strutturati e raccolga metriche e dati traccia utilizzando OpenTelemetry, aggiorna l'invocazione dell'app per precaricare il modulo di strumentazione con il flag --require
di Node.js. L'utilizzo del flag --require
garantisce che OpenTelemetry venga inizializzato prima dell'avvio dell'app. Per ulteriori informazioni, consulta la pagina relativa al recupero di OpenTelemetry Node.js
Iniziata.
Il seguente esempio di codice illustra un Dockerfile che passa il flag --require
:
Configura il logging strutturato
per includere le informazioni di traccia all'interno dei log in formato JSON scritti in
standard, configura la tua app per generare log strutturati in formato JSON.
Fastify utilizza il framework di log Pino e fornisce un logger in ogni
come gestore delle richieste. Il seguente esempio di codice illustra un LoggerOptions
Pino
che configura l'app per generare log strutturati JSON:
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 essere utilizzati per correlare un log con una traccia:
logging.googleapis.com/trace
: nome risorsa della traccia associata a la 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.
Per utilizzare la configurazione Pino con Fastify, passa l'oggetto di configurazione logger quando creando l'app Fastify:
Scrittura di log strutturati
Per scrivere log strutturati che rimandano a una traccia, utilizza il logger Pino fornito da Fastify. Ad esempio, la seguente istruzione mostra come chiamare
il metodo Logger.info()
:
request.log.info({subRequests}, 'handle /multi request');
OpenTelemetry compila automaticamente le voci di log di Pino con il contesto dell'ambito dell'ambito attivo corrente nel contesto OpenTelemetry. Questo contesto di intervallo viene quindi incluso nei log JSON descritti in Configura il logging strutturato.
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 Fastify. Per indirizzare
di telemetria a Google Cloud, questo esempio utilizza il valore di OpenTelemetry Collector
configurato
con gli esportatori di Google. L'app ha due endpoint:
L'endpoint
/multi
è gestito dalla funzionehandleMulti
. Il generatore di carico nell'app invia richieste all'endpoint/multi
. Quando questo quando un endpoint riceve una richiesta, invia da 3 a 7 l'endpoint/single
sul server locale.L'endpoint
/single
è gestito dalla funzionehandleSingle
. 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 il sample:
-
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-js
Vai alla directory di esempio:
cd opentelemetry-operations-js/samples/instrumentation-quickstart
Crea ed esegui l'esempio:
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_milliseconds/histogram
registra la durata delle richieste del server e archivia i risultati in un istogramma.Prometheus/http_client_duration_milliseconds/histogram
registra la durata delle richieste del 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.
- 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 Target Prometheus.
- Nel menu Categorie di metriche attive, seleziona Http.
- Seleziona una metrica nel menu Metriche attive.
- 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 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 Selezionare le metriche durante l'utilizzo di Metrics Explorer.
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 URI
/multi
. Nel grafico di Gantt, all'interno del riquadro Dettagli traccia, seleziona l'intervallo con l'etichetta
/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 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
In Esplora log puoi esaminare i log e anche visualizzare le tracce associate, se presenti.
-
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.
Fai clic su Tracce in una voce di log con "handle /multi-richiesta" quindi seleziona Visualizza dettagli traccia.
Si apre un riquadro Dettagli su Trace che mostra la traccia selezionata.
Per ulteriori informazioni sull'utilizzo 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