Skip to content

Latest commit

 

History

History
130 lines (102 loc) · 4.53 KB

OBSERVABILITY.md

File metadata and controls

130 lines (102 loc) · 4.53 KB

Observability with OpenTelemetry

This Cloud Spanner client supports OpenTelemetry Traces, which gives insight into the client internals and aids in debugging/troubleshooting production issues.

By default, the functionality is disabled. You shall need to add OpenTelemetry dependencies, and must configure and enable OpenTelemetry with appropriate exporters at the startup of your application:

Table of contents:

Tracing

OpenTelemetry Dependencies

Add the following dependencies in your package.json or install them directly.

// Required packages for OpenTelemetry SDKs
"@opentelemetry/sdk-trace-base": "^1.26.0",
"@opentelemetry/sdk-trace-node": "^1.26.0",

// Package to use Google Cloud Trace exporter
"@google-cloud/opentelemetry-cloud-trace-exporter": "^2.4.1",

// Packages to enable gRPC instrumentation
"@opentelemetry/instrumentation": "^0.53.0",
"@opentelemetry/instrumentation-grpc": "^0.53.0",

OpenTelemetry Configuration

const {
  NodeTracerProvider,
  TraceIdRatioBasedSampler,
} = require('@opentelemetry/sdk-trace-node');
const {
  BatchSpanProcessor,
} = require('@opentelemetry/sdk-trace-base');
const {
  TraceExporter,
} = require('@google-cloud/opentelemetry-cloud-trace-exporter');
const exporter = new TraceExporter();

// Create the tracerProvider that the exporter shall be attached to.
const provider = new NodeTracerProvider({resource: resource});
provider.addSpanProcessor(new BatchSpanProcessor(exporter));

// Create the Cloud Spanner Client.
const {Spanner} = require('@google-cloud/spanner');
const spanner = new Spanner({
  projectId: projectId,
  observabilityOptions: {
    // Inject the TracerProvider via SpannerOptions or
    // register it as a global by invoking `provider.register()`
    tracerProvider: provider,
  },
});

SQL Statement span annotation

To allow your SQL statements to be annotated in the appropriate spans, you need to opt-in, because SQL statements can contain sensitive personally-identifiable-information (PII).

You can opt-in by either:

  • Setting the environment variable SPANNER_ENABLE_EXTENDED_TRACING=true before your application is started
  • In code, setting enableExtendedTracing: true in your SpannerOptions before creating the Cloud Spanner client
const spanner = new Spanner({
  projectId: projectId,
  observabilityOptions: {
    tracerProvider: provider,
    enableExtendedTracing: true,
  }
}),

End to end tracing

In addition to client-side tracing, you can opt in for end-to-end tracing. End-to-end tracing helps you understand and debug latency issues that are specific to Spanner. Refer here for more information.

To configure end-to-end tracing.

  1. Opt in for end-to-end tracing. You can opt-in by either:
  • Setting the environment variable SPANNER_ENABLE_END_TO_END_TRACING=true before your application is started
  • In code, setting enableEndToEndTracing: true in your SpannerOptions before creating the Cloud Spanner client
const spanner = new Spanner({
  projectId: projectId,
  observabilityOptions: {
    tracerProvider: provider,
    enableEndToEndTracing: true,
  }
}),
  1. Set the trace context propagation in OpenTelemetry.
const {propagation} = require('@opentelemetry/api');
const {W3CTraceContextPropagator} = require('@opentelemetry/core');
propagation.setGlobalPropagator(new W3CTraceContextPropagator());

OpenTelemetry gRPC instrumentation

Optionally, you can enable OpenTelemetry gRPC instrumentation which produces traces of executed remote procedure calls (RPCs) in your programs by these imports and instantiation. You could pass in the traceProvider or register it globally by invoking tracerProvider.register()

  const {registerInstrumentations} = require('@opentelemetry/instrumentation');
  const {GrpcInstrumentation} = require('@opentelemetry/instrumentation-grpc');
  registerInstrumentations({
    tracerProvider: tracerProvider,
    instrumentations: [new GrpcInstrumentation()],
  });

Tracing Sample

For more information please see this sample code