@aztec/telemetry-client 0.0.1-commit.fce3e4f → 0.0.1-commit.ff7989d6c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dest/attributes.d.ts +18 -1
  2. package/dest/attributes.d.ts.map +1 -1
  3. package/dest/attributes.js +9 -0
  4. package/dest/bench.d.ts +3 -1
  5. package/dest/bench.d.ts.map +1 -1
  6. package/dest/bench.js +24 -14
  7. package/dest/l1_metrics.d.ts +2 -2
  8. package/dest/l1_metrics.d.ts.map +1 -1
  9. package/dest/l1_metrics.js +4 -20
  10. package/dest/lmdb_metrics.d.ts +3 -3
  11. package/dest/lmdb_metrics.d.ts.map +1 -1
  12. package/dest/lmdb_metrics.js +4 -20
  13. package/dest/metric-utils.d.ts +24 -0
  14. package/dest/metric-utils.d.ts.map +1 -0
  15. package/dest/metric-utils.js +59 -0
  16. package/dest/metrics.d.ts +283 -206
  17. package/dest/metrics.d.ts.map +1 -1
  18. package/dest/metrics.js +1435 -204
  19. package/dest/nodejs_metrics_monitor.d.ts +3 -5
  20. package/dest/nodejs_metrics_monitor.d.ts.map +1 -1
  21. package/dest/nodejs_metrics_monitor.js +19 -40
  22. package/dest/noop.d.ts +6 -3
  23. package/dest/noop.d.ts.map +1 -1
  24. package/dest/noop.js +32 -1
  25. package/dest/otel.d.ts +5 -3
  26. package/dest/otel.d.ts.map +1 -1
  27. package/dest/otel.js +51 -4
  28. package/dest/otel_resource.d.ts +1 -1
  29. package/dest/otel_resource.d.ts.map +1 -1
  30. package/dest/otel_resource.js +14 -2
  31. package/dest/prom_otel_adapter.d.ts +4 -4
  32. package/dest/prom_otel_adapter.d.ts.map +1 -1
  33. package/dest/prom_otel_adapter.js +19 -10
  34. package/dest/start.d.ts +3 -2
  35. package/dest/start.d.ts.map +1 -1
  36. package/dest/start.js +4 -3
  37. package/dest/telemetry.d.ts +37 -25
  38. package/dest/telemetry.d.ts.map +1 -1
  39. package/dest/telemetry.js +46 -23
  40. package/dest/wrappers/l2_block_stream.d.ts +4 -3
  41. package/dest/wrappers/l2_block_stream.d.ts.map +1 -1
  42. package/dest/wrappers/l2_block_stream.js +385 -11
  43. package/package.json +8 -6
  44. package/src/attributes.ts +25 -0
  45. package/src/bench.ts +27 -15
  46. package/src/l1_metrics.ts +5 -20
  47. package/src/lmdb_metrics.ts +5 -26
  48. package/src/metric-utils.ts +75 -0
  49. package/src/metrics.ts +1513 -249
  50. package/src/nodejs_metrics_monitor.ts +18 -51
  51. package/src/noop.ts +61 -3
  52. package/src/otel.ts +76 -6
  53. package/src/otel_resource.ts +19 -2
  54. package/src/prom_otel_adapter.ts +16 -23
  55. package/src/start.ts +8 -4
  56. package/src/telemetry.ts +105 -66
  57. package/src/wrappers/l2_block_stream.ts +6 -2
@@ -2,18 +2,11 @@ import type { Observable } from '@opentelemetry/api';
2
2
  import { type EventLoopUtilization, type IntervalHistogram, monitorEventLoopDelay, performance } from 'node:perf_hooks';
3
3
 
4
4
  import * as Attributes from './attributes.js';
5
+ import { createUpDownCounterWithDefault } from './metric-utils.js';
5
6
  import * as Metrics from './metrics.js';
6
- import {
7
- type BatchObservableResult,
8
- type Meter,
9
- type ObservableGauge,
10
- type UpDownCounter,
11
- ValueType,
12
- } from './telemetry.js';
13
-
14
- /**
15
- * Detector for custom Aztec attributes
16
- */
7
+ import type { BatchObservableResult, Meter, ObservableGauge, UpDownCounter } from './telemetry.js';
8
+
9
+ /** Monitors Node.js runtime metrics */
17
10
  export class NodejsMetricsMonitor {
18
11
  private eventLoopDelayGauges: {
19
12
  min: ObservableGauge;
@@ -38,53 +31,27 @@ export class NodejsMetricsMonitor {
38
31
  private eventLoopDelay: IntervalHistogram;
39
32
 
40
33
  constructor(private meter: Meter) {
41
- const nsObsGauge = (name: (typeof Metrics)[keyof typeof Metrics], description: string) =>
42
- meter.createObservableGauge(name, {
43
- unit: 'ns',
44
- valueType: ValueType.INT,
45
- description,
46
- });
47
-
48
34
  this.eventLoopDelayGauges = {
49
- min: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MIN, 'Minimum delay of the event loop'),
50
- mean: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MEAN, 'Mean delay of the event loop'),
51
- max: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MAX, 'Max delay of the event loop'),
52
- stddev: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_STDDEV, 'Stddev delay of the event loop'),
53
- p50: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P50, 'P50 delay of the event loop'),
54
- p90: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P90, 'P90 delay of the event loop'),
55
- p99: nsObsGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P99, 'P99 delay of the event loop'),
35
+ min: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MIN),
36
+ mean: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MEAN),
37
+ max: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_MAX),
38
+ stddev: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_STDDEV),
39
+ p50: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P50),
40
+ p90: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P90),
41
+ p99: meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_DELAY_P99),
56
42
  };
57
43
 
58
- this.eventLoopUilization = meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_UTILIZATION, {
59
- valueType: ValueType.DOUBLE,
60
- description: 'How busy is the event loop',
44
+ this.eventLoopUilization = meter.createObservableGauge(Metrics.NODEJS_EVENT_LOOP_UTILIZATION);
45
+ this.eventLoopTime = createUpDownCounterWithDefault(meter, Metrics.NODEJS_EVENT_LOOP_TIME, {
46
+ [Attributes.NODEJS_EVENT_LOOP_STATE]: ['idle', 'active'],
61
47
  });
62
-
63
- this.eventLoopTime = meter.createUpDownCounter(Metrics.NODEJS_EVENT_LOOP_TIME, {
64
- unit: 'ms',
65
- valueType: ValueType.INT,
66
- description: 'How much time the event loop has spent in a given state',
67
- });
68
-
69
48
  this.eventLoopDelay = monitorEventLoopDelay();
70
49
 
71
50
  this.memoryGauges = {
72
- heapUsed: meter.createObservableGauge(Metrics.NODEJS_MEMORY_HEAP_USAGE, {
73
- unit: 'By',
74
- description: 'Memory used by the V8 heap',
75
- }),
76
- heapTotal: meter.createObservableGauge(Metrics.NODEJS_MEMORY_HEAP_TOTAL, {
77
- unit: 'By',
78
- description: 'The max size the V8 heap can grow to',
79
- }),
80
- arrayBuffers: meter.createObservableGauge(Metrics.NODEJS_MEMORY_BUFFER_USAGE, {
81
- unit: 'By',
82
- description: 'Memory allocated for buffers (includes native memory used)',
83
- }),
84
- external: meter.createObservableGauge(Metrics.NODEJS_MEMORY_NATIVE_USAGE, {
85
- unit: 'By',
86
- description: 'Memory allocated for native C++ objects',
87
- }),
51
+ heapUsed: meter.createObservableGauge(Metrics.NODEJS_MEMORY_HEAP_USAGE),
52
+ heapTotal: meter.createObservableGauge(Metrics.NODEJS_MEMORY_HEAP_TOTAL),
53
+ arrayBuffers: meter.createObservableGauge(Metrics.NODEJS_MEMORY_BUFFER_USAGE),
54
+ external: meter.createObservableGauge(Metrics.NODEJS_MEMORY_NATIVE_USAGE),
88
55
  };
89
56
  }
90
57
 
package/src/noop.ts CHANGED
@@ -1,13 +1,63 @@
1
- import { type Meter, type Span, type SpanContext, type Tracer, createNoopMeter } from '@opentelemetry/api';
1
+ import { type Context, type Span, type SpanContext, type Tracer, createNoopMeter } from '@opentelemetry/api';
2
2
 
3
- import type { TelemetryClient } from './telemetry.js';
3
+ import type { MetricDefinition } from './metrics.js';
4
+ import type {
5
+ Gauge,
6
+ Histogram,
7
+ Meter,
8
+ ObservableGauge,
9
+ ObservableUpDownCounter,
10
+ TelemetryClient,
11
+ UpDownCounter,
12
+ } from './telemetry.js';
13
+
14
+ /** A no-op meter that implements our custom Meter interface */
15
+ class NoopMeter implements Meter {
16
+ private otelMeter = createNoopMeter();
17
+
18
+ createGauge(_metric: MetricDefinition): Gauge {
19
+ return this.otelMeter.createGauge('');
20
+ }
21
+
22
+ createObservableGauge(_metric: MetricDefinition): ObservableGauge {
23
+ return this.otelMeter.createObservableGauge('');
24
+ }
25
+
26
+ createHistogram(_metric: MetricDefinition, _extraOptions?: Parameters<Meter['createHistogram']>[1]): Histogram {
27
+ return this.otelMeter.createHistogram('');
28
+ }
29
+
30
+ createUpDownCounter(_metric: MetricDefinition): UpDownCounter {
31
+ return this.otelMeter.createUpDownCounter('');
32
+ }
33
+
34
+ createObservableUpDownCounter(_metric: MetricDefinition): ObservableUpDownCounter {
35
+ return this.otelMeter.createObservableUpDownCounter('');
36
+ }
37
+
38
+ addBatchObservableCallback(
39
+ callback: Parameters<Meter['addBatchObservableCallback']>[0],
40
+ observables: Parameters<Meter['addBatchObservableCallback']>[1],
41
+ ): void {
42
+ this.otelMeter.addBatchObservableCallback(callback, observables);
43
+ }
44
+
45
+ removeBatchObservableCallback(
46
+ callback: Parameters<Meter['removeBatchObservableCallback']>[0],
47
+ observables: Parameters<Meter['removeBatchObservableCallback']>[1],
48
+ ): void {
49
+ this.otelMeter.removeBatchObservableCallback(callback, observables);
50
+ }
51
+ }
4
52
 
5
53
  export class NoopTelemetryClient implements TelemetryClient {
54
+ private meter = new NoopMeter();
55
+
6
56
  setExportedPublicTelemetry(_prefixes: string[]): void {}
7
57
  setPublicTelemetryCollectFrom(_roles: string[]): void {}
8
58
 
9
59
  getMeter(): Meter {
10
- return createNoopMeter();
60
+ return this.meter;
11
61
  }
12
62
 
13
63
  getTracer(): Tracer {
@@ -25,6 +75,14 @@ export class NoopTelemetryClient implements TelemetryClient {
25
75
  isEnabled() {
26
76
  return false;
27
77
  }
78
+
79
+ getTraceContext(): string | undefined {
80
+ return undefined;
81
+ }
82
+
83
+ extractPropagatedContext(_traceContext: string): Context | undefined {
84
+ return undefined;
85
+ }
28
86
  }
29
87
 
30
88
  // @opentelemetry/api internally uses NoopTracer and NoopSpan but they're not exported
package/src/otel.ts CHANGED
@@ -1,16 +1,20 @@
1
1
  import { type LogData, type Logger, addLogDataHandler } from '@aztec/foundation/log';
2
2
 
3
3
  import {
4
+ type Context,
4
5
  DiagConsoleLogger,
5
6
  DiagLogLevel,
6
- type Meter,
7
+ type Meter as OtelMeter,
8
+ ROOT_CONTEXT,
7
9
  type Tracer,
8
10
  type TracerProvider,
9
11
  context,
10
12
  diag,
11
13
  isSpanContextValid,
14
+ propagation,
12
15
  trace,
13
16
  } from '@opentelemetry/api';
17
+ import { W3CTraceContextPropagator } from '@opentelemetry/core';
14
18
  import { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';
15
19
  import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
16
20
  import { HostMetrics } from '@opentelemetry/host-metrics';
@@ -28,18 +32,67 @@ import { BatchSpanProcessor, NodeTracerProvider } from '@opentelemetry/sdk-trace
28
32
  import { ATTR_SERVICE_NAME, ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
29
33
 
30
34
  import type { TelemetryClientConfig } from './config.js';
35
+ import { toMetricOptions } from './metric-utils.js';
36
+ import type { MetricDefinition } from './metrics.js';
31
37
  import { NodejsMetricsMonitor } from './nodejs_metrics_monitor.js';
32
38
  import { OtelFilterMetricExporter, PublicOtelFilterMetricExporter } from './otel_filter_metric_exporter.js';
33
39
  import { registerOtelLoggerProvider } from './otel_logger_provider.js';
34
40
  import { getOtelResource } from './otel_resource.js';
35
- import type { TelemetryClient } from './telemetry.js';
41
+ import type {
42
+ Gauge,
43
+ Histogram,
44
+ Meter,
45
+ ObservableGauge,
46
+ ObservableUpDownCounter,
47
+ TelemetryClient,
48
+ UpDownCounter,
49
+ } from './telemetry.js';
50
+
51
+ /** Wraps an OpenTelemetry Meter to implement our custom Meter interface */
52
+ class WrappedMeter implements Meter {
53
+ constructor(private otelMeter: OtelMeter) {}
54
+
55
+ createGauge(metric: MetricDefinition): Gauge {
56
+ return this.otelMeter.createGauge(metric.name, toMetricOptions(metric));
57
+ }
58
+
59
+ createObservableGauge(metric: MetricDefinition): ObservableGauge {
60
+ return this.otelMeter.createObservableGauge(metric.name, toMetricOptions(metric));
61
+ }
62
+
63
+ createHistogram(metric: MetricDefinition, extraOptions?: Parameters<Meter['createHistogram']>[1]): Histogram {
64
+ return this.otelMeter.createHistogram(metric.name, { ...toMetricOptions(metric), ...extraOptions });
65
+ }
66
+
67
+ createUpDownCounter(metric: MetricDefinition): UpDownCounter {
68
+ return this.otelMeter.createUpDownCounter(metric.name, toMetricOptions(metric));
69
+ }
70
+
71
+ createObservableUpDownCounter(metric: MetricDefinition): ObservableUpDownCounter {
72
+ return this.otelMeter.createObservableUpDownCounter(metric.name, toMetricOptions(metric));
73
+ }
74
+
75
+ addBatchObservableCallback(
76
+ callback: Parameters<Meter['addBatchObservableCallback']>[0],
77
+ observables: Parameters<Meter['addBatchObservableCallback']>[1],
78
+ ): void {
79
+ this.otelMeter.addBatchObservableCallback(callback, observables);
80
+ }
81
+
82
+ removeBatchObservableCallback(
83
+ callback: Parameters<Meter['removeBatchObservableCallback']>[0],
84
+ observables: Parameters<Meter['removeBatchObservableCallback']>[1],
85
+ ): void {
86
+ this.otelMeter.removeBatchObservableCallback(callback, observables);
87
+ }
88
+ }
36
89
 
37
90
  export type OpenTelemetryClientFactory = (resource: IResource, log: Logger) => OpenTelemetryClient;
38
91
 
39
92
  export class OpenTelemetryClient implements TelemetryClient {
40
93
  hostMetrics: HostMetrics | undefined;
41
94
  nodejsMetricsMonitor: NodejsMetricsMonitor | undefined;
42
- private meters: Map<string, Meter> = new Map<string, Meter>();
95
+ private meters: Map<string, WrappedMeter> = new Map<string, WrappedMeter>();
43
96
  private tracers: Map<string, Tracer> = new Map<string, Tracer>();
44
97
 
45
98
  protected constructor(
@@ -62,7 +115,8 @@ export class OpenTelemetryClient implements TelemetryClient {
62
115
  getMeter(name: string): Meter {
63
116
  let meter = this.meters.get(name);
64
117
  if (!meter) {
65
- meter = this.meterProvider.getMeter(name, this.resource.attributes[ATTR_SERVICE_VERSION] as string);
118
+ const otelMeter = this.meterProvider.getMeter(name, this.resource.attributes[ATTR_SERVICE_VERSION] as string);
119
+ meter = new WrappedMeter(otelMeter);
66
120
  this.meters.set(name, meter);
67
121
  }
68
122
  return meter;
@@ -100,9 +154,10 @@ export class OpenTelemetryClient implements TelemetryClient {
100
154
  meterProvider: this.meterProvider,
101
155
  });
102
156
 
103
- this.nodejsMetricsMonitor = new NodejsMetricsMonitor(
157
+ const nodejsMeter = new WrappedMeter(
104
158
  this.meterProvider.getMeter(this.resource.attributes[ATTR_SERVICE_NAME] as string),
105
159
  );
160
+ this.nodejsMetricsMonitor = new NodejsMetricsMonitor(nodejsMeter);
106
161
 
107
162
  this.hostMetrics.start();
108
163
  this.nodejsMetricsMonitor.start();
@@ -138,6 +193,19 @@ export class OpenTelemetryClient implements TelemetryClient {
138
193
  ]);
139
194
  }
140
195
 
196
+ public getTraceContext(): string | undefined {
197
+ const carrier: Record<string, string> = {};
198
+ propagation.inject(context.active(), carrier);
199
+ return carrier['traceparent'];
200
+ }
201
+
202
+ public extractPropagatedContext(traceContext: string): Context {
203
+ const extractedContext = propagation.extract(ROOT_CONTEXT, {
204
+ traceparent: traceContext,
205
+ });
206
+ return extractedContext;
207
+ }
208
+
141
209
  public static createMeterProvider(
142
210
  resource: IResource,
143
211
  exporters: Array<PeriodicExportingMetricReaderOptions>,
@@ -279,7 +347,9 @@ export class OpenTelemetryClient implements TelemetryClient {
279
347
  : [],
280
348
  });
281
349
 
282
- tracerProvider.register();
350
+ tracerProvider.register({
351
+ propagator: new W3CTraceContextPropagator(),
352
+ });
283
353
 
284
354
  const exporters: PeriodicExportingMetricReaderOptions[] = [];
285
355
  if (config.metricsCollectorUrl) {
@@ -7,10 +7,26 @@ import {
7
7
  osDetectorSync,
8
8
  serviceInstanceIdDetectorSync,
9
9
  } from '@opentelemetry/resources';
10
- import { SEMRESATTRS_SERVICE_NAME } from '@opentelemetry/semantic-conventions';
10
+ import { ATTR_SERVICE_NAME, ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
11
+ import { readFileSync } from 'fs';
12
+ import { dirname, resolve } from 'path';
13
+ import { fileURLToPath } from 'url';
11
14
 
12
15
  import { AZTEC_NODE_ROLE, AZTEC_REGISTRY_ADDRESS, AZTEC_ROLLUP_ADDRESS, AZTEC_ROLLUP_VERSION } from './attributes.js';
13
16
 
17
+ /** Reads the Aztec client version from the release manifest. */
18
+ function getAztecVersion(): string | undefined {
19
+ try {
20
+ const releasePleasePath = resolve(
21
+ dirname(fileURLToPath(import.meta.url)),
22
+ '../../../.release-please-manifest.json',
23
+ );
24
+ return JSON.parse(readFileSync(releasePleasePath, 'utf-8'))['.'];
25
+ } catch {
26
+ return undefined;
27
+ }
28
+ }
29
+
14
30
  export function getOtelResource(): IResource {
15
31
  const resource = detectResourcesSync({
16
32
  detectors: [
@@ -42,7 +58,8 @@ const aztecNetworkDetectorSync: DetectorSync = {
42
58
  }
43
59
  const aztecAttributes = {
44
60
  // this gets overwritten by OTEL_RESOURCE_ATTRIBUTES (if set)
45
- [SEMRESATTRS_SERVICE_NAME]: role ? `aztec-${role}` : undefined,
61
+ [ATTR_SERVICE_NAME]: role ? `aztec-${role}` : undefined,
62
+ [ATTR_SERVICE_VERSION]: getAztecVersion(),
46
63
  [AZTEC_NODE_ROLE]: role,
47
64
  [AZTEC_ROLLUP_VERSION]: process.env.ROLLUP_VERSION ?? 'canonical',
48
65
  [AZTEC_ROLLUP_ADDRESS]: process.env.ROLLUP_CONTRACT_ADDRESS,
@@ -1,9 +1,10 @@
1
- import { type Logger, createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import { Timer } from '@aztec/foundation/timer';
3
3
 
4
4
  import { Registry } from 'prom-client';
5
5
 
6
- import type { Histogram, Meter, MetricsType, ObservableGauge, TelemetryClient } from './telemetry.js';
6
+ import type { MetricDefinition } from './metrics.js';
7
+ import type { Histogram, Meter, ObservableGauge, TelemetryClient } from './telemetry.js';
7
8
 
8
9
  /**
9
10
  * Types matching the gossipsub and libp2p services
@@ -94,9 +95,8 @@ export class OtelGauge<Labels extends LabelsGeneric = NoLabels> implements IGaug
94
95
  help: string,
95
96
  private labelNames: Array<keyof Labels> = [],
96
97
  ) {
97
- this.gauge = meter.createObservableGauge(name as MetricsType, {
98
- description: help,
99
- });
98
+ const metricDef: MetricDefinition = { name, description: help };
99
+ this.gauge = meter.createObservableGauge(metricDef);
100
100
 
101
101
  // Only observe in the callback when collect() is called
102
102
  this.gauge.addCallback(this.handleObservation.bind(this));
@@ -214,8 +214,8 @@ export class OtelHistogram<Labels extends LabelsGeneric = NoLabels> implements I
214
214
  buckets: number[] = [],
215
215
  private labelNames: Array<keyof Labels> = [],
216
216
  ) {
217
- this.histogram = meter.createHistogram(name as MetricsType, {
218
- description: help,
217
+ const metricDef: MetricDefinition = { name, description: help };
218
+ this.histogram = meter.createHistogram(metricDef, {
219
219
  advice: buckets.length ? { explicitBucketBoundaries: buckets } : undefined,
220
220
  });
221
221
  }
@@ -289,15 +289,9 @@ export class OtelAvgMinMax<Labels extends LabelsGeneric = NoLabels> implements I
289
289
  ) {
290
290
  // Create three separate gauges for avg, min, and max
291
291
  this.gauges = {
292
- avg: meter.createObservableGauge(`${name}_avg` as MetricsType, {
293
- description: `${help} (average)`,
294
- }),
295
- min: meter.createObservableGauge(`${name}_min` as MetricsType, {
296
- description: `${help} (minimum)`,
297
- }),
298
- max: meter.createObservableGauge(`${name}_max` as MetricsType, {
299
- description: `${help} (maximum)`,
300
- }),
292
+ avg: meter.createObservableGauge({ name: `${name}_avg`, description: `${help} (average)` }),
293
+ min: meter.createObservableGauge({ name: `${name}_min`, description: `${help} (minimum)` }),
294
+ max: meter.createObservableGauge({ name: `${name}_max`, description: `${help} (maximum)` }),
301
295
  };
302
296
 
303
297
  // Register callbacks for each gauge
@@ -416,12 +410,11 @@ function parseLabelsSafely<Labels extends LabelsGeneric>(labelStr: string, logge
416
410
  */
417
411
  export class OtelMetricsAdapter extends Registry implements MetricsRegister {
418
412
  private readonly meter: Meter;
413
+ private logger: Logger;
419
414
 
420
- constructor(
421
- telemetryClient: TelemetryClient,
422
- private logger: Logger = createLogger('telemetry:otel-metrics-adapter'),
423
- ) {
415
+ constructor(telemetryClient: TelemetryClient, bindings?: LoggerBindings) {
424
416
  super();
417
+ this.logger = createLogger('telemetry:otel-metrics-adapter', bindings);
425
418
  this.meter = telemetryClient.getMeter('metrics-adapter');
426
419
  }
427
420
 
@@ -429,7 +422,7 @@ export class OtelMetricsAdapter extends Registry implements MetricsRegister {
429
422
  return new OtelGauge<Labels>(
430
423
  this.logger,
431
424
  this.meter,
432
- configuration.name as MetricsType,
425
+ configuration.name,
433
426
  configuration.help,
434
427
  configuration.labelNames,
435
428
  );
@@ -439,7 +432,7 @@ export class OtelMetricsAdapter extends Registry implements MetricsRegister {
439
432
  return new OtelHistogram<Labels>(
440
433
  this.logger,
441
434
  this.meter,
442
- configuration.name as MetricsType,
435
+ configuration.name,
443
436
  configuration.help,
444
437
  configuration.buckets,
445
438
  configuration.labelNames,
@@ -450,7 +443,7 @@ export class OtelMetricsAdapter extends Registry implements MetricsRegister {
450
443
  return new OtelAvgMinMax<Labels>(
451
444
  this.logger,
452
445
  this.meter,
453
- configuration.name as MetricsType,
446
+ configuration.name,
454
447
  configuration.help,
455
448
  configuration.labelNames,
456
449
  );
package/src/start.ts CHANGED
@@ -1,8 +1,7 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
 
3
3
  import type { TelemetryClientConfig } from './config.js';
4
4
  import { NoopTelemetryClient } from './noop.js';
5
- import { OpenTelemetryClient } from './otel.js';
6
5
  import type { TelemetryClient } from './telemetry.js';
7
6
 
8
7
  export * from './config.js';
@@ -10,8 +9,11 @@ export * from './config.js';
10
9
  let initialized = false;
11
10
  let telemetry: TelemetryClient = new NoopTelemetryClient();
12
11
 
13
- export function initTelemetryClient(config: TelemetryClientConfig): TelemetryClient {
14
- const log = createLogger('telemetry:client');
12
+ export async function initTelemetryClient(
13
+ config: TelemetryClientConfig,
14
+ bindings?: LoggerBindings,
15
+ ): Promise<TelemetryClient> {
16
+ const log = createLogger('telemetry:client', bindings);
15
17
  if (initialized) {
16
18
  log.warn('Telemetry client has already been initialized once');
17
19
  return telemetry;
@@ -19,6 +21,8 @@ export function initTelemetryClient(config: TelemetryClientConfig): TelemetryCli
19
21
 
20
22
  if (config.metricsCollectorUrl || config.publicMetricsCollectorUrl) {
21
23
  log.info(`Using OpenTelemetry client with custom collector`);
24
+ // Lazy load OpenTelemetry to avoid loading heavy deps at startup
25
+ const { OpenTelemetryClient } = await import('./otel.js');
22
26
  telemetry = OpenTelemetryClient.createAndStart(config, log);
23
27
  } else {
24
28
  log.info('Using NoopTelemetryClient');