1e47bc23c3
Finish up OTEL example with HTTP (we don't recommend grpc because that package is needlessly large). Also added a link to a simple repo with otel collector and few backends: https://github.com/vercel/opentelemetry-collector-dev-setup --------- Co-authored-by: Tim Neutkens <tim@timneutkens.nl>
22 lines
783 B
TypeScript
22 lines
783 B
TypeScript
import { Resource } from '@opentelemetry/resources'
|
|
import { SemanticResourceAttributes } from '@opentelemetry/semantic-conventions'
|
|
import {
|
|
NodeTracerProvider,
|
|
SimpleSpanProcessor,
|
|
} from '@opentelemetry/sdk-trace-node'
|
|
|
|
// You can use gRPC exporter instead
|
|
import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http'
|
|
|
|
// Next.js expects you to use to register TraceProvider. It won't work if you use NodeSDK.
|
|
// We use registered provider to create traces inside of Next.js internals.
|
|
const provider = new NodeTracerProvider({
|
|
resource: new Resource({
|
|
[SemanticResourceAttributes.SERVICE_NAME]: 'next-app',
|
|
}),
|
|
})
|
|
|
|
provider.addSpanProcessor(new SimpleSpanProcessor(new OTLPTraceExporter({})))
|
|
|
|
// Make sure to register you provider
|
|
provider.register()
|