Skip to content

scayle/nuxt-opentelemetry

Repository files navigation

@scayle/nuxt-opentelemetry

@scayle/nuxt-opentelemetry

A Nuxt module for OpenTelemetry integration.

Installation

# Using pnpm
pnpm add @scayle/nuxt-opentelemetry

# Using yarn
yarn add @scayle/nuxt-opentelemetry

# Using npm
npm install @scayle/nuxt-opentelemetry

Usage

export default defineNuxtConfig({
  modules: ['@scayle/nuxt-opentelemetry'],
  runtimeConfig: {
    opentelemetry: {
      // Set default runtime config options here.
      // They can be overridden at runtime with NUXT_OPENTELEMETRY_ environment variables
      // The properties which can be set at runtime are defined below
    },
  },
  opentelemetry: {
    // Set build-time module configuration options here
  },
})

This module will instrument requests handled by Nitro according to Semantic Conventions for HTTP Spans v1.26.0

Module Configuration

The internal module can be configured through module options or runtime environment variables. The following options are available.

  • enabled or NUXT_OPENTELEMETRY_ENABLED

    • This option enables or disables the module. If enabled is set to false at build-time, the module will not install any plugins or modify the entrypoint. If enabled is set to false at runtime, the plugin will be installed, but spans will not be created for Nitro requests. They may be created for other instrumentations.
  • pathBlocklist or NUXT_OPENTELEMETRY_PATH_BLOCKLIST

    • This option allows ignoring requests for paths that match the pattern. It can be a regular expression string or plain string. For example, you could use the option { pathBlocklist: '^/api/up' } to skip creating spans for health check requests.
  • pathReplace or NUXT_OPENTELEMETRY_PATH_REPLACE

    • The Nitro span names are derived from the route path. This option can be used to rewrite the path that is used in the name. It should be an array with two elements. The first element is the pattern to match, as a regular expression string or plain string. The second element is the text to replace the match with. This can be used to use the same span name when the paths only differ by a locale prefix. For example: ['^/(en|de|fr)/', '/:locale/']
  • requestHeaders or NUXT_OPENTELEMETRY_REQUEST_HEADERS

    • This option allows selecting which request headers to include as span attributes. They will be added as http.request.header.{name}. The values are case-insensitive when matching headers. It will be normalized to lowercase in the attribute name. Example: { requestHeaders: ['x-custom-header', 'accept'] } or NUXT_OPENTELEMETRY_REQUEST_HEADERS=["x-custom-header", "accept"]
  • responseHeaders or NUXT_OPENTELEMETRY_RESPONSE_HEADERS

    • This option allows selecting which response headers to include as span attributes. They will be added as http.response.header.{name}. The values are case-insensitive when matching headers. It will be normalized to lowercase in the attribute name. Example: { responseHeaders: ['content-type'] } or NUXT_OPENTELEMETRY_REQUEST_HEADERS=["content-type"]
  • disableAutomaticInitialization or NUXT_OPENTELEMETRY_DISABLE_AUTOMATIC_INITIALIZATION

    • This option allows for manual instrumentation of the application via a Nitro plugin. This enables adjustment of the application's instrumentation to better suit specific needs.

Including and Excluding modules

The below options are passed to import-in-the-middle to control its interception behavior. You can read more about the behavior of these options in its documentation.

  • include An array of module identifiers to include from hooking
  • exclude An array of module identifiers to exclude from hooking

Custom instrumentation

To leverage custom instrumentation, set disableAutomaticInstrumentation to true. This enables the creation of custom instrumentation within a Nitro plugin located in the ./server/plugins directory, offering enhanced customization and adaptability for your instrumentation configuration. The example provided demonstrates a basic instrumentation setup utilizing the @opentelemetry/sdk-node.

// ./server/plugins/instrumentation.ts
import { defineNitroPlugin } from 'nitropack/runtime/plugin'
import type { NitroApp } from 'nitropack/types'
import { getNodeAutoInstrumentations } from '@opentelemetry/auto-instrumentations-node'
import { NodeSDK } from '@opentelemetry/sdk-node'
import { PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics'
import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-proto'
import { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-proto'

export default defineNitroPlugin((_nitroApp: NitroApp) => {
  const sdk = new NodeSDK({
    traceExporter: new OTLPTraceExporter(),
    metricReader: new PeriodicExportingMetricReader({
      exporter: new OTLPMetricExporter(),
    }),
    instrumentations: [
      getNodeAutoInstrumentations(),
    ],
  })

  sdk.start()
})

License

Licensed under the MIT License

What is SCAYLE?

SCAYLE is a full-featured e-commerce software solution that comes with flexible APIs. Within SCAYLE, you can manage all aspects of your shop, such as products, stocks, customers, and transactions.

Learn more about SCAYLE’s architecture and commerce modules in the Docs.

Other channels

About

A Nuxt module for OpenTelemetry integration.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •