Neste documento, descrevemos como modificar um app JavaScript de Node.js para coletar dados de rastreamento e métrica usando o framework de código aberto OpenTelemetry, e como gravar registros JSON estruturados para saída padrão. Este documento também fornece informações sobre um aplicativo Node.js de exemplo que pode ser instalado e executado. O app usa o framework da Web Fastify e está configurado para gerar métricas, traces e registros.
Para saber mais sobre instrumentação, consulte os seguintes documentos:
Sobre a instrumentação manual e automática
Para essa linguagem, o OpenTelemetry define a instrumentação automática como a prática de coletar telemetria de bibliotecas e frameworks sem fazer alterações no código. No entanto, você tem módulos de instalação e define variáveis de ambiente.
Este documento não descreve as informações automáticas. Para mais informações sobre esse tópico, consulte Instrumentação automática para nó.
Para informações gerais, consulte Instrumentação do OpenTelemetry para o Node.
Antes de começar
Enable the Cloud Logging, Cloud Monitoring, and Cloud Trace APIs.
Instrumentar o app para coletar traces, métricas e registros
Para instrumentar o app para coletar dados de rastreamento e métrica e gravar um JSON estruturado para saída padrão, siga as etapas a seguir, conforme descrito nas próximas seções deste documento:
- Configurar o OpenTelemetry
- Configurar seu app para pré-carregar a configuração do OpenTelemetry
- Configurar a geração de registros estruturados
- Gravar registros estruturados
Configurar o OpenTelemetry
A configuração padrão do SDK do Node.js para OpenTelemetry exporta traces usando o protocolo OTLP. Ela também configura o OpenTelemetry para usar o formato Contexto de Rastreamento do W3C para propagar o contexto do trace. Essa configuração garante que os períodos tenham o relacionamento pai-filho correto em um trace.
O exemplo de código a seguir ilustra um módulo JavaScript para configurar o OpenTelemetry.
Para ver o exemplo completo, clique em more_vert Mais e selecione Ver no GitHub.
O exemplo de código anterior configura o OpenTelemetry para exportar métricas usando o protocolo OTLP e usa o pacote @opentelemetry/auto-instrumentations-node
para configurar todas as instrumentações Node.js disponíveis.
Para garantir que toda a telemetria pendente seja transferida e que as conexões sejam fechadas corretamente antes do encerramento do aplicativo, o gerenciador SIGTERM
chama shutdown
.
Para mais informações e opções de configuração, consulte Instrumentação automática do Node.js para OpenTelemetry.
Configurar seu app para pré-carregar a configuração do OpenTelemetry
Para configurar o app para gravar registros estruturados e coletar métricas e rastrear
dados com o OpenTelemetry, atualize a invocação do app para pré-carregar o
módulo de instrumentação com a flag --require
do Node.js. O uso
da flag --require
garante que o OpenTelemetry seja inicializado antes que o
app seja
iniciado. Para mais informações, consulte Primeiras etapas do Node.js para OpenTelemetry.
O exemplo de código a seguir ilustra um Dockerfile transmitindo a flag --require
:
Configurar a geração de registros estruturados
Para incluir as informações de trace como parte dos registros formatados em JSON gravados na
saída padrão, configure seu app para gerar registros estruturados no formato JSON.
O Fastify usa o framework de registro do Pino e fornece um registrador em cada
gerenciador de solicitações. O exemplo de código a seguir ilustra um objeto LoggerOptions
do Pino que configura o app para gerar registros estruturados JSON:
A configuração anterior extrai informações sobre o período ativo da mensagem de registro e, em seguida, adiciona essas informações como atributos ao registro estruturado JSON. Esses atributos podem ser usados para correlacionar um registro com um trace:
logging.googleapis.com/trace
: nome do recurso do trace associado à entrada de registro.logging.googleapis.com/spanId
: o ID do período com o trace associado à entrada de registro.logging.googleapis.com/trace_sampled
: o valor desse campo precisa sertrue
oufalse
.
Para mais informações sobre esses campos, consulte a estrutura
LogEntry
.
Para usar a configuração do Pino com o Fastify, transmita o objeto de configuração do logger ao criar o app Fastify:
Gravar registros estruturados
Para gravar registros estruturados que vinculam a um trace, use o logger do Pino fornecido pelo
Fastify. Por exemplo, a instrução a seguir mostra como chamar o método Logger.info()
:
request.log.info({subRequests}, 'handle /multi request');
O OpenTelemetry preenche automaticamente as entradas de registro do Pino com o contexto do período do período ativo atual no OpenTelemetry Context. Esse contexto de período é incluído nos registros JSON, conforme descrito em Configurar a geração de registros estruturados.
Executar um app de exemplo configurado para coletar telemetria
O app de exemplo usa formatos neutros em relação a fornecedores, incluindo JSON para registros e OTLP
para métricas e traces, além do framework do Fastify. Para rotear
a telemetria para o Google Cloud, este exemplo usa o Collector
do OpenTelemetry
configurado com os exportadores do Google. O app tem dois endpoints:
O endpoint
/multi
é processado pela funçãohandleMulti
. O gerador de carga no app emite solicitações para o endpoint/multi
. Quando esse endpoint recebe uma solicitação, ele envia de três a sete solicitações para o endpoint/single
no servidor local.O endpoint
/single
é processado pela funçãohandleSingle
. Quando esse endpoint recebe uma solicitação, ele fica suspenso por um pequeno atraso e depois responde com uma string.
Fazer o download e implantar o app
Para executar a amostra:
-
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.
Clone o repositório:
git clone https://github.com/GoogleCloudPlatform/opentelemetry-operations-js
Acesse o diretório da amostra:
cd opentelemetry-operations-js/samples/instrumentation-quickstart
Crie e execute a amostra:
docker compose up --abort-on-container-exit
Se você não estiver usando o Cloud Shell, execute o aplicativo com a variável de ambiente
GOOGLE_APPLICATION_CREDENTIALS
apontando para um arquivo de credenciais. O Application Default Credentials fornece um arquivo de credenciais em$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
Ver suas métricas
A instrumentação do OpenTelemetry no app de amostra gera métricas do Prometheus, que podem ser visualizadas usando o Metrics Explorer:
Prometheus/http_server_duration_milliseconds/histogram
registra a duração das solicitações do servidor e armazena os resultados em um histograma.Prometheus/http_client_duration_milliseconds/histogram
registra a duração das solicitações do cliente e armazena os resultados em um histograma.
-
No Console do Google Cloud, acesse a página do leaderboard Metrics Explorer:
Se você usar a barra de pesquisa para encontrar essa página, selecione o resultado com o subtítulo Monitoramento.
- No elemento Metric, expanda o menu Selecionar uma métrica,
digite
http_server
na barra de filtro e use os submenus para selecionar um tipo de recurso e métrica específicos:- No menu Active resources, selecione Prometheus Target.
- No menu Categorias de métrica ativas, selecione Instância.
- No menu Métricas ativas, selecione uma métrica de faturamento†.
- Clique em Aplicar.
- Configure a visualização dos dados.
Quando as medições de uma métrica são cumulativas, o Metrics Explorer normaliza automaticamente os dados medidos pelo período de alinhamento, o que resulta na exibição de uma taxa no gráfico. Para mais informações, consulte Tipos, tipos e conversões.
Quando valores inteiros ou duplos são medidos, como acontece com as duas métricas
counter
, o Metrics Explorer soma automaticamente todas as séries temporais. Para visualizar os dados das rotas HTTP/multi
e/single
, defina o primeiro menu da entrada Agregação como Nenhum.Para mais informações sobre como configurar um gráfico, consulte Selecionar métricas ao usar o Metrics Explorer.
Visualizar os rastros
Para visualizar os dados de trace, faça o seguinte:
-
No console do Google Cloud, acesse a página Explorador de traces:
Acessar o Explorador de traces
Também é possível encontrar essa página usando a barra de pesquisa.
- No gráfico de dispersão, selecione um rastro com o URI de
/multi
. No diagrama de Gantt no painel Detalhes do trace, selecione o período rotulado como
/multi
.Um painel é aberto com informações sobre a solicitação HTTP. Esses detalhes incluem o método, o código de status, o número de bytes e o user agent do autor da chamada.
Para visualizar os registros associados a esse trace, selecione a guia Registros e eventos.
A guia mostra registros individuais. Para exibir os detalhes da entrada de registro, expanda a entrada de registro. Também é possível clicar em Ver registros e ver o registro usando a Análise de registros.
Para mais informações sobre como usar o explorador do Cloud Trace, consulte Encontrar e explorar traces.
Acessar os registros
Na Análise de registros, é possível inspecionar os registros e visualizar os traces associados, quando eles existirem.
-
No console do Google Cloud, acesse a página do Análise de registros.
Acessar a Análise de registros
Se você usar a barra de pesquisa para encontrar essa página, selecione o resultado com o subtítulo Monitoring.
Localize um registro com a descrição de
handle /multi request
.Para ver os detalhes do registro, expanda a entrada.
Clique em Traces em uma entrada de registro com a mensagem "handle /multi request" e selecione View trace details.
O painel Detalhes do trace é aberto e mostra o trace selecionado.
Para mais informações sobre como usar a Análise de registros, consulte Ver registros usando a Análise de registros.
A seguir
- OpenTelemetry
- Especificação do OTLP
- Geração de registros estruturados
- Solução de problemas do Managed Service para Prometheus
- Resolver problemas do Cloud Trace