forked from redis/node-redis
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathotel-metrics.js
More file actions
58 lines (47 loc) · 1.45 KB
/
otel-metrics.js
File metadata and controls
58 lines (47 loc) · 1.45 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// OpenTelemetry metrics example for node-redis.
// Demonstrates enablement, command activity, and metric export verification.
import { createClient, OpenTelemetry } from 'redis';
import { metrics } from '@opentelemetry/api';
import {
ConsoleMetricExporter,
MeterProvider,
PeriodicExportingMetricReader
} from '@opentelemetry/sdk-metrics';
// Export metrics to console for easy local verification.
const reader = new PeriodicExportingMetricReader({
exporter: new ConsoleMetricExporter(),
});
const meterProvider = new MeterProvider({
readers: [reader]
});
metrics.setGlobalMeterProvider(meterProvider);
// Enable OpenTelemetry before creating clients
OpenTelemetry.init({
metrics: {
enabled: true,
enabledMetricGroups: ['command', 'connection-basic', 'resiliency'],
}
});
const client = createClient();
client.on('error', (err) => {
console.error('Redis client error:', err);
});
try {
await client.connect();
// Normal command traffic.
await client.ping();
await client.set('otel:example:key', '1');
await client.get('otel:example:key');
// Generate a handled error to demonstrate resiliency metrics.
await client.hSet('otel:example:hash', 'field', 'value');
try {
await client.incr('otel:example:hash');
} catch (err) {
console.log('Expected command error:', err);
}
// Force export so output is visible immediately.
await meterProvider.forceFlush();
} finally {
client.destroy();
await meterProvider.shutdown();
}