@aztec/telemetry-client 0.0.1-commit.c7c42ec → 0.0.1-commit.c949de6bc
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.
- package/dest/attributes.d.ts +9 -1
- package/dest/attributes.d.ts.map +1 -1
- package/dest/attributes.js +4 -0
- package/dest/bench.d.ts +3 -1
- package/dest/bench.d.ts.map +1 -1
- package/dest/bench.js +24 -14
- package/dest/l1_metrics.d.ts +2 -2
- package/dest/l1_metrics.d.ts.map +1 -1
- package/dest/l1_metrics.js +4 -20
- package/dest/lmdb_metrics.d.ts +3 -3
- package/dest/lmdb_metrics.d.ts.map +1 -1
- package/dest/lmdb_metrics.js +4 -20
- package/dest/metric-utils.d.ts +24 -0
- package/dest/metric-utils.d.ts.map +1 -0
- package/dest/metric-utils.js +59 -0
- package/dest/metrics.d.ts +285 -224
- package/dest/metrics.d.ts.map +1 -1
- package/dest/metrics.js +1445 -222
- package/dest/nodejs_metrics_monitor.d.ts +3 -5
- package/dest/nodejs_metrics_monitor.d.ts.map +1 -1
- package/dest/nodejs_metrics_monitor.js +19 -40
- package/dest/noop.d.ts +6 -3
- package/dest/noop.d.ts.map +1 -1
- package/dest/noop.js +32 -1
- package/dest/otel.d.ts +5 -3
- package/dest/otel.d.ts.map +1 -1
- package/dest/otel.js +51 -4
- package/dest/otel_resource.d.ts +1 -1
- package/dest/otel_resource.d.ts.map +1 -1
- package/dest/otel_resource.js +14 -2
- package/dest/prom_otel_adapter.d.ts +4 -4
- package/dest/prom_otel_adapter.d.ts.map +1 -1
- package/dest/prom_otel_adapter.js +19 -10
- package/dest/start.d.ts +3 -2
- package/dest/start.d.ts.map +1 -1
- package/dest/start.js +2 -2
- package/dest/telemetry.d.ts +37 -25
- package/dest/telemetry.d.ts.map +1 -1
- package/dest/telemetry.js +46 -23
- package/dest/wrappers/l2_block_stream.d.ts +2 -2
- package/dest/wrappers/l2_block_stream.d.ts.map +1 -1
- package/dest/wrappers/l2_block_stream.js +385 -11
- package/package.json +4 -4
- package/src/attributes.ts +12 -0
- package/src/bench.ts +27 -15
- package/src/l1_metrics.ts +5 -20
- package/src/lmdb_metrics.ts +5 -26
- package/src/metric-utils.ts +75 -0
- package/src/metrics.ts +1503 -250
- package/src/nodejs_metrics_monitor.ts +18 -51
- package/src/noop.ts +61 -3
- package/src/otel.ts +76 -6
- package/src/otel_resource.ts +19 -2
- package/src/prom_otel_adapter.ts +16 -23
- package/src/start.ts +6 -3
- package/src/telemetry.ts +105 -66
- package/src/wrappers/l2_block_stream.ts +4 -1
|
@@ -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
|
-
|
|
8
|
-
|
|
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:
|
|
50
|
-
mean:
|
|
51
|
-
max:
|
|
52
|
-
stddev:
|
|
53
|
-
p50:
|
|
54
|
-
p90:
|
|
55
|
-
p99:
|
|
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
|
-
|
|
60
|
-
|
|
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
|
-
|
|
74
|
-
|
|
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
|
|
1
|
+
import { type Context, type Span, type SpanContext, type Tracer, createNoopMeter } from '@opentelemetry/api';
|
|
2
2
|
|
|
3
|
-
import type {
|
|
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
|
|
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 {
|
|
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,
|
|
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
|
-
|
|
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
|
-
|
|
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) {
|
package/src/otel_resource.ts
CHANGED
|
@@ -7,10 +7,26 @@ import {
|
|
|
7
7
|
osDetectorSync,
|
|
8
8
|
serviceInstanceIdDetectorSync,
|
|
9
9
|
} from '@opentelemetry/resources';
|
|
10
|
-
import {
|
|
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
|
-
[
|
|
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,
|
package/src/prom_otel_adapter.ts
CHANGED
|
@@ -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 {
|
|
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
|
-
|
|
98
|
-
|
|
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
|
-
|
|
218
|
-
|
|
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`
|
|
293
|
-
|
|
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
|
|
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
|
|
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
|
|
446
|
+
configuration.name,
|
|
454
447
|
configuration.help,
|
|
455
448
|
configuration.labelNames,
|
|
456
449
|
);
|
package/src/start.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
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';
|
|
@@ -9,8 +9,11 @@ export * from './config.js';
|
|
|
9
9
|
let initialized = false;
|
|
10
10
|
let telemetry: TelemetryClient = new NoopTelemetryClient();
|
|
11
11
|
|
|
12
|
-
export async function initTelemetryClient(
|
|
13
|
-
|
|
12
|
+
export async function initTelemetryClient(
|
|
13
|
+
config: TelemetryClientConfig,
|
|
14
|
+
bindings?: LoggerBindings,
|
|
15
|
+
): Promise<TelemetryClient> {
|
|
16
|
+
const log = createLogger('telemetry:client', bindings);
|
|
14
17
|
if (initialized) {
|
|
15
18
|
log.warn('Telemetry client has already been initialized once');
|
|
16
19
|
return telemetry;
|