# Using pnpm
pnpm add @scayle/nuxt-opentelemetry
# Using yarn
yarn add @scayle/nuxt-opentelemetry
# Using npm
npm install @scayle/nuxt-opentelemetry
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
The internal module can be configured through module options or runtime environment variables. The following options are available.
-
enabled
orNUXT_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. Ifenabled
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.
- This option enables or disables the module.
If
-
pathBlocklist
orNUXT_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.
- 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
-
pathReplace
orNUXT_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/']
- 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:
-
requestHeaders
orNUXT_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'] }
orNUXT_OPENTELEMETRY_REQUEST_HEADERS=["x-custom-header", "accept"]
- This option allows selecting which request headers to include as span attributes. They will be added as
-
responseHeaders
orNUXT_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'] }
orNUXT_OPENTELEMETRY_REQUEST_HEADERS=["content-type"]
- This option allows selecting which response headers to include as span attributes. They will be added as
-
disableAutomaticInitialization
orNUXT_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.
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 hookingexclude
An array of module identifiers to exclude from hooking
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()
})
Licensed under the MIT License
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.