Skip to main content

Setup OpenTelemetry

Backstage uses OpenTelemetery to instrument its components by reporting traces and metrics.

This tutorial shows how to setup exporters in your Backstage backend package. For demonstration purposes we will use the simple console exporters.

Install dependencies

We will use the OpenTelemetry Node SDK and the auto-instrumentations-node packages.

Backstage packages, such as the catalog, uses the OpenTelemetry API to send custom traces and metrics. The auto-instrumentations-node will automatically create spans for code called in libraries like Express.

yarn --cwd packages/backend add @opentelemetry/sdk-node \
@opentelemetry/auto-instrumentations-node \
@opentelemetry/sdk-metrics \
@opentelemetry/sdk-trace-node

Configure

In your packages/backend folder, create an instrumentation.js file.

const { NodeSDK } = require('@opentelemetry/sdk-node');
const { ConsoleSpanExporter } = require('@opentelemetry/sdk-trace-node');
const {
getNodeAutoInstrumentations,
} = require('@opentelemetry/auto-instrumentations-node');
const {
PeriodicExportingMetricReader,
ConsoleMetricExporter,
} = require('@opentelemetry/sdk-metrics');

const sdk = new NodeSDK({
traceExporter: new ConsoleSpanExporter(),
metricReader: new PeriodicExportingMetricReader({
exporter: new ConsoleMetricExporter(),
}),
instrumentations: [getNodeAutoInstrumentations()],
});

sdk.start();

You probably won't need all of the instrumentation inside getNodeAutoInstrumentations() so make sure to check the documentation and tweak it properly.

It's important to setup the NodeSDK and the automatic instrumentation before importing any library.

This is why we will use the nodejs --require flag when we start up the application.

In your Dockerfile add the --require flag which points to the instrumentation.js file


# We need the instrumentation file inside the Docker image so we can use it with --require
COPY --chown=node:node packages/backend/instrumentation.js ./

CMD ["node", "packages/backend", "--config", "app-config.yaml"]
CMD ["node", "--require", "./instrumentation.js", "packages/backend", "--config", "app-config.yaml"]

Run Backstage

The above configuration will only work in production once your start a Docker container from the image.

To be able to test locally you can import the ./instrumentation.js file at the top (before all imports) of your backend index.ts file

import '../instrumentation.js'
// Other imports
...

You can now start your Backstage instance as usual, using yarn dev.

When the backend is started, you should see in your console traces and metrics emitted by OpenTelemetry.

Of course in production you probably won't use the console exporters but instead send traces and metrics to an OpenTelemetry Collector or other exporter using OTLP exporters.

If you need to disable/configure some OpenTelemetry feature there are lots of environment variables which you can tweak.

References