Note: This is an experimental package under active development. New releases may include breaking changes.
This package provides the full OpenTelemetry SDK for Node.js including tracing and metrics.
Note: Much of OpenTelemetry JS documentation is written assuming the compiled application is run as CommonJS. For more details on ECMAScript Modules vs CommonJS, refer to esm-support.
To get started you need to install @opentelemetry/sdk-node
, a metrics and/or tracing exporter, and any appropriate instrumentation for the node modules used by your application.
$ # Install the SDK
$ npm install @opentelemetry/sdk-node
$ # Install exporters and plugins
$ npm install \
@opentelemetry/exporter-jaeger \ # add tracing exporters as needed
@opentelemetry/exporter-prometheus \ # add metrics exporters as needed
@opentelemetry/instrumentation-http # add instrumentations as needed
$ # or install all officially supported core and contrib plugins
$ npm install @opentelemetry/auto-instrumentations-node
Note: this example is for Node.js. See examples/opentelemetry-web for a browser example.
Before any other module in your application is loaded, you must initialize the SDK. If you fail to initialize the SDK or initialize it too late, no-op implementations will be provided to any library which acquires a tracer or meter from the API.
This example uses Jaeger and Prometheus, but exporters exist for other tracing backends.
As shown in the installation instructions, exporters passed to the SDK must be installed alongside @opentelemetry/sdk-node
.
const opentelemetry = require("@opentelemetry/sdk-node");
const { JaegerExporter } = require("@opentelemetry/exporter-jaeger");
const { PrometheusExporter } = require("@opentelemetry/exporter-prometheus");
const {
getNodeAutoInstrumentations,
} = require("@opentelemetry/auto-instrumentations-node");
const jaegerExporter = new JaegerExporter();
const prometheusExporter = new PrometheusExporter();
const sdk = new opentelemetry.NodeSDK({
// Optional - if omitted, the tracing SDK will be initialized from environment variables
traceExporter: jaegerExporter,
// Optional - If omitted, the metrics SDK will not be initialized
metricReader: prometheusExporter,
// Optional - you can use the metapackage or load each instrumentation individually
instrumentations: [getNodeAutoInstrumentations()],
// See the Configuration section below for additional configuration options
});
sdk.start();
// You can also use the shutdown method to gracefully shut down the SDK before process shutdown
// or on some operating system signal.
const process = require("process");
process.on("SIGTERM", () => {
sdk
.shutdown()
.then(
() => console.log("SDK shut down successfully"),
(err) => console.log("Error shutting down SDK", err)
)
.finally(() => process.exit(0));
});
Below is a full list of configuration options which may be passed into the NodeSDK
constructor;
Detect resources automatically from the environment using the default resource detectors. Default true
.
Use a custom context manager. Default: AsyncLocalStorageContextManager
Use a custom propagator. Default: CompositePropagator using W3C Trace Context and Baggage
Deprecated, please use logRecordProcessors instead.
An array of log record processors to register to the logger provider.
Merge user-provided resources with the default resource. Default true
.
The default will change to false
in a future iteration of this package.
Add a MetricReader
that will be passed to the MeterProvider
. If metricReader
is not configured,
the metrics SDK will not be initialized and registered.
A list of views to be passed to the MeterProvider
.
Accepts an array of View-instances.
This parameter can be used to configure explicit bucket sizes of histogram metrics.
Configure instrumentations. By default none of the instrumentation is enabled, if you want to enable them you can use either metapackage or configure each instrumentation individually.
Configure a resource. Resources may also be detected by using the autoDetectResources
method of the SDK.
Configure resource detectors. By default, the resource detectors are [envDetector, processDetector, hostDetector].
NOTE: In order to enable the detection, the parameter autoDetectResources
has to be true
.
If resourceDetectors
was not set, you can also use the environment variable OTEL_NODE_RESOURCE_DETECTORS
to enable only certain detectors, or completely disable them:
env
host
os
process
serviceinstance
(experimental)all
- enable all resource detectors above- NOTE: future versions of
@opentelemetry/sdk-node
may include additional detectors that will be covered by this scope.
- NOTE: future versions of
none
- disable resource detection
For example, to enable only the env
, host
detectors:
export OTEL_NODE_RESOURCE_DETECTORS="env,host"
Configure a custom sampler. By default, all traces will be sampled.
Deprecated, please use spanProcessors instead.
An array of span processors to register to the tracer provider.
Configure a trace exporter. If an exporter is configured, it will be used with a BatchSpanProcessor. If an exporter OR span processor is not configured programmatically, this package will auto setup the default otlp
exporter with http/protobuf
protocol with a BatchSpanProcessor
.
Configure tracing parameters. These are the same trace parameters used to configure a tracer.
Configure the service name.
Disable the SDK by setting the OTEL_SDK_DISABLED
environment variable to true
.
Set the log level by setting the OTEL_LOG_LEVEL
environment variable to enums:
NONE
,ERROR
,WARN
,INFO
,DEBUG
,VERBOSE
,ALL
.
The default level is INFO
.
This is an alternative to programmatically configuring an exporter or span processor. For traces this package will auto setup the default otlp
exporter with http/protobuf
protocol if traceExporter
or spanProcessor
hasn't been passed into the NodeSDK
constructor.
Environment variable | Description |
---|---|
OTEL_TRACES_EXPORTER | List of exporters to be used for tracing, separated by commas. Options include otlp , jaeger , zipkin , and none . Default is otlp . none means no autoconfigured exporter. |
OTEL_LOGS_EXPORTER | List of exporters to be used for logging, separated by commas. Options include otlp , console and none . Default is otlp . none means no autoconfigured exporter. |
Environment variable | Description |
---|---|
OTEL_EXPORTER_OTLP_PROTOCOL | The transport protocol to use on OTLP trace, metric, and log requests. Options include grpc , http/protobuf , and http/json . Default is http/protobuf . |
OTEL_EXPORTER_OTLP_TRACES_PROTOCOL | The transport protocol to use on OTLP trace requests. Options include grpc , http/protobuf , and http/json . Default is http/protobuf . |
OTEL_EXPORTER_OTLP_METRICS_PROTOCOL | The transport protocol to use on OTLP metric requests. Options include grpc , http/protobuf , and http/json . Default is http/protobuf . |
OTEL_EXPORTER_OTLP_LOGS_PROTOCOL | The transport protocol to use on OTLP log requests. Options include grpc , http/protobuf , and http/json . Default is http/protobuf . |
OTEL_METRICS_EXPORTER | Metrics exporter to be used. options are otlp , prometheus , console or none . |
OTEL_METRIC_EXPORT_INTERVAL | The export interval when using a push Metric Reader. Default is 60000 . |
OTEL_METRIC_EXPORT_TIMEOUT | The export timeout when using a push Metric Reader. Default is 30000 . |
Additionally, you can specify other applicable environment variables that apply to each exporter such as the following:
- OTLP exporter environment configuration
- Zipkin exporter environment configuration
- Jaeger exporter environment configuration
- For more information on OpenTelemetry, visit: https://opentelemetry.io/
- For more about OpenTelemetry JavaScript: /~https://github.com/open-telemetry/opentelemetry-js
- For help or feedback on this project, join us in GitHub Discussions
Apache 2.0 - See LICENSE for more information.