Package Exports
- @sentry/opentelemetry
- @sentry/opentelemetry/cjs/index.js
- @sentry/opentelemetry/esm/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@sentry/opentelemetry) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Official Sentry SDK for OpenTelemetry
This package allows you to send your OpenTelemetry trace data to Sentry via OpenTelemetry SpanProcessors.
This SDK is considered experimental and in an alpha state. It may experience breaking changes. Please reach out on GitHub if you have any feedback/concerns.
Installation
npm install @sentry/opentelemetry
# Or yarn
yarn add @sentry/opentelemetryNote that @sentry/opentelemetry depends on the following peer dependencies:
@opentelemetry/apiversion1.0.0or greater@opentelemetry/coreversion1.0.0or greater@opentelemetry/semantic-conventionsversion1.0.0or greater@opentelemetry/sdk-trace-baseversion1.0.0or greater, or a package that implements that, like@opentelemetry/sdk-node.
Usage
This package exposes a few building blocks you can add to your OpenTelemetry setup in order to capture OpenTelemetry traces to Sentry.
This is how you can use this in your app:
- Setup the global hub for OpenTelemetry compatibility - ensure
setupGlobalHub()is called before anything else! - Initialize Sentry, e.g.
@sentry/node- make sure to setinstrumenter: 'otel'in the SDKinit({})! - Call
setupEventContextTrace(client) - Add
SentrySampleras sampler - Add
SentrySpanProcessoras span processor - Add a context manager wrapped via
wrapContextManagerClass - Add
SentryPropagatoras propagator - Setup OTEL-powered async context strategy for Sentry via
setOpenTelemetryContextAsyncContextStrategy()
For example, you could set this up as follows:
import * as Sentry from '@sentry/node';
import {
getCurrentHub,
setupGlobalHub,
SentryPropagator,
SentrySampler,
SentrySpanProcessor,
setupEventContextTrace,
wrapContextManagerClass,
setOpenTelemetryContextAsyncContextStrategy,
} from '@sentry/opentelemetry';
import { AsyncLocalStorageContextManager } from '@opentelemetry/context-async-hooks';
function setupSentry() {
setupGlobalHub();
Sentry.init({
dsn: 'xxx',
instrumenter: 'otel'
});
const client = getCurrentHub().getClient();
setupEventContextTrace(client);
const provider = new BasicTracerProvider({
sampler: new SentrySampler(client),
});
provider.addSpanProcessor(new SentrySpanProcessor());
const SentryContextManager = wrapContextManagerClass(AsyncLocalStorageContextManager);
// Initialize the provider
provider.register({
propagator: new SentryPropagator(),
contextManager: new SentryContextManager(),
});
setOpenTelemetryContextAsyncContextStrategy();
}A full setup example can be found in node-experimental.