@scayle/nuxt-opentelemetry v0.13.8
@scayle/nuxt-opentelemetry
Installation
# Using pnpm
pnpm add @scayle/nuxt-opentelemetry
# Using yarn
yarn add @scayle/nuxt-opentelemetry
# Using npm
npm install @scayle/nuxt-opentelemetryUsage
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.
enabledorNUXT_OPENTELEMETRY_ENABLED- This option enables or disables the module.
If
enabledis set to false at build-time, the module will not install any plugins or modify the entrypoint. Ifenabledis 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
pathBlocklistorNUXT_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
pathReplaceorNUXT_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:
requestHeadersorNUXT_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
responseHeadersorNUXT_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
disableAutomaticInitializationorNUXT_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.
includeAn array of module identifiers to include from hookingexcludeAn 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
8 months ago
5 months ago
5 months ago
5 months ago
6 months ago
6 months ago
6 months ago
5 months ago
5 months ago
5 months ago
5 months ago
7 months ago
7 months ago
10 months ago
8 months ago
10 months ago
7 months ago
9 months ago
12 months ago
7 months ago
9 months ago
11 months ago
8 months ago
10 months ago
11 months ago
6 months ago
9 months ago
7 months ago
9 months ago
12 months ago
9 months ago
6 months ago
6 months ago
6 months ago
6 months ago
8 months ago
7 months ago
8 months ago
8 months ago
11 months ago
12 months ago
8 months ago
8 months ago
11 months ago
12 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago