0.48.0 • Published 5 months ago

@opentelemetry/instrumentation-nestjs-core v0.48.0

Weekly downloads
-
License
Apache-2.0
Repository
-
Last release
5 months ago

OpenTelemetry NestJS Instrumentation for Node.js

NPM Published Version Apache License

This module provides automatic instrumentation for the Nest framework module, which may be loaded using the @opentelemetry/sdk-trace-node package and is included in the @opentelemetry/auto-instrumentations-node bundle.

If total installation size is not constrained, it is recommended to use the @opentelemetry/auto-instrumentations-node bundle with @opentelemetry/sdk-node for the most seamless instrumentation experience.

Compatible with OpenTelemetry JS API and SDK 1.0+.

Installation

npm install --save @opentelemetry/instrumentation-nestjs-core

Supported Versions

Usage

OpenTelemetry Nest Instrumentation allows the user to automatically collect trace data from the controller handlers and export them to the backend of choice.

To load a specific instrumentation (Nest in this case), specify it in the registerInstrumentations' configuration.

const { NodeTracerProvider } = require('@opentelemetry/sdk-trace-node');
const { NestInstrumentation } = require('@opentelemetry/instrumentation-nestjs-core');
const { registerInstrumentations } = require('@opentelemetry/instrumentation');

const provider = new NodeTracerProvider();
provider.register();

registerInstrumentations({
  instrumentations: [
    new NestInstrumentation(),
  ],
});

Emitted Spans

Namenestjs.typeDescriptionIncluded attributes
Create Nest Appapp_creationTraces the bootup for the Nest App. The NestFactory(Static).create call.nestjs.module
<ControllerName>.<memberName>request_contextTraces the whole request context.http.*, nestjs.callback
<memberName>handlerTraces the work of a specific controller member function.nestjs.callback

Semantic Conventions

This package uses @opentelemetry/semantic-conventions version 1.22+, which implements Semantic Convention Version 1.7.0

Attributes collected:

AttributeShort Description
component*"@nestjs/core"
nestjs.version*Version of instrumented @nestjs/core package
nestjs.type*See NestType
nestjs.moduleNest module class name
nestjs.controllerNest controller class name
nestjs.callbackThe function name of the member in the controller
http.methodHTTP method
http.urlFull request URL
http.routeRoute assigned to handler. Ex: /users/:id

* included in all of the spans.

Useful links

License

Apache 2.0 - See LICENSE for more information.

0.42.0

11 months ago

0.43.0

11 months ago

0.48.0

5 months ago

0.46.0

6 months ago

0.47.0

5 months ago

0.44.0

10 months ago

0.45.0

7 months ago

0.44.1

8 months ago

0.41.0

12 months ago

0.40.0

1 year ago

0.39.0

1 year ago

0.38.0

1 year ago

0.37.1

1 year ago

0.37.0

1 year ago

0.36.0

2 years ago

0.35.0

2 years ago

0.34.0

2 years ago

0.33.4

2 years ago

0.33.3

2 years ago

0.33.2

2 years ago

0.33.1

2 years ago

0.33.0

2 years ago

0.32.5

2 years ago

0.32.4

2 years ago

0.32.3

2 years ago

0.32.2

3 years ago

0.32.1

3 years ago

0.32.0

3 years ago

0.31.1

3 years ago

0.31.0

3 years ago

0.30.0

3 years ago

0.29.0

3 years ago

0.28.1

4 years ago

0.28.3

4 years ago

0.28.2

4 years ago

0.28.0

4 years ago

0.27.0

4 years ago

0.26.0

4 years ago

0.25.0

4 years ago