Telemetry
OpenTelemetry observability integration tools.
Useful for getting more visibility into your own programs.
Namespaces
APIs for working with the OpenTelemetry observability framework. Deno can export traces, metrics, and logs to OpenTelemetry compatible backends via the OTLP protocol.
Variables
A ContextManager compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.ContextManager.html
A MeterProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.MeterProvider.html
A TracerProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.TracerProvider.html
namespace Deno.telemetry
APIs for working with the OpenTelemetry observability framework. Deno can export traces, metrics, and logs to OpenTelemetry compatible backends via the OTLP protocol.
Deno automatically instruments the runtime with OpenTelemetry traces and
metrics. This data is exported via OTLP to OpenTelemetry compatible
backends. User logs from the console API are exported as OpenTelemetry
logs via OTLP.
User code can also create custom traces, metrics, and logs using the
OpenTelemetry API. This is done using the official OpenTelemetry package
for JavaScript:
npm:@opentelemetry/api.
Deno integrates with this package to provide tracing, metrics, and trace
context propagation between native Deno APIs (like Deno.serve or fetch)
and custom user code. Deno automatically registers the providers with the
OpenTelemetry API, so users can start creating custom traces, metrics, and
logs without any additional setup.
Examples #
import { trace } from "npm:@opentelemetry/api@1";
const tracer = trace.getTracer("example-tracer");
async function doWork() {
return tracer.startActiveSpan("doWork", async (span) => {
span.setAttribute("key", "value");
await new Promise((resolve) => setTimeout(resolve, 1000));
span.end();
});
}
Deno.serve(async (req) => {
await doWork();
const resp = await fetch("https://example.com");
return resp;
});
Variables #
A ContextManager compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.ContextManager.html
A MeterProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.MeterProvider.html
A TracerProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.TracerProvider.html
variable Deno.telemetry.contextManager
A ContextManager compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.ContextManager.html
This is a singleton object that implements the OpenTelemetry ContextManager interface.
Type #
any variable Deno.telemetry.meterProvider
A MeterProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.MeterProvider.html
This is a singleton object that implements the OpenTelemetry MeterProvider interface.
Type #
any variable Deno.telemetry.tracerProvider
A TracerProvider compatible with OpenTelemetry.js https://open-telemetry.github.io/opentelemetry-js/interfaces/_opentelemetry_api.TracerProvider.html
This is a singleton object that implements the OpenTelemetry TracerProvider interface.
Type #
any 