From adc94cf09c86112051f72055852efcc977e4a04a Mon Sep 17 00:00:00 2001 From: Chocobozzz Date: Wed, 27 Jul 2022 16:19:25 +0200 Subject: Add live and viewers otel metrics --- server/lib/opentelemetry/metric-helpers/index.ts | 2 ++ .../metric-helpers/lives-observers-builder.ts | 21 +++++++++++++++++++ .../metric-helpers/viewers-observers-builder.ts | 24 ++++++++++++++++++++++ server/lib/opentelemetry/metrics.ts | 14 ++++++++++++- 4 files changed, 60 insertions(+), 1 deletion(-) create mode 100644 server/lib/opentelemetry/metric-helpers/lives-observers-builder.ts create mode 100644 server/lib/opentelemetry/metric-helpers/viewers-observers-builder.ts (limited to 'server/lib/opentelemetry') diff --git a/server/lib/opentelemetry/metric-helpers/index.ts b/server/lib/opentelemetry/metric-helpers/index.ts index ff0aff9fd..1b3813743 100644 --- a/server/lib/opentelemetry/metric-helpers/index.ts +++ b/server/lib/opentelemetry/metric-helpers/index.ts @@ -1,3 +1,5 @@ +export * from './lives-observers-builder' export * from './job-queue-observers-builder' export * from './nodejs-observers-builder' export * from './stats-observers-builder' +export * from './viewers-observers-builder' diff --git a/server/lib/opentelemetry/metric-helpers/lives-observers-builder.ts b/server/lib/opentelemetry/metric-helpers/lives-observers-builder.ts new file mode 100644 index 000000000..e27bd8548 --- /dev/null +++ b/server/lib/opentelemetry/metric-helpers/lives-observers-builder.ts @@ -0,0 +1,21 @@ +import { Meter } from '@opentelemetry/api-metrics' +import { VideoModel } from '@server/models/video/video' + +export class LivesObserversBuilder { + + constructor (private readonly meter: Meter) { + + } + + buildObservers () { + this.meter.createObservableGauge('peertube_running_lives_total', { + description: 'Total running lives on the instance' + }).addCallback(async observableResult => { + const local = await VideoModel.countLives({ remote: false, mode: 'published' }) + const remote = await VideoModel.countLives({ remote: true, mode: 'published' }) + + observableResult.observe(local, { liveOrigin: 'local' }) + observableResult.observe(remote, { liveOrigin: 'remote' }) + }) + } +} diff --git a/server/lib/opentelemetry/metric-helpers/viewers-observers-builder.ts b/server/lib/opentelemetry/metric-helpers/viewers-observers-builder.ts new file mode 100644 index 000000000..634e5bbc9 --- /dev/null +++ b/server/lib/opentelemetry/metric-helpers/viewers-observers-builder.ts @@ -0,0 +1,24 @@ +import { Meter } from '@opentelemetry/api-metrics' +import { VideoScope, ViewerScope } from '@server/lib/views/shared' +import { VideoViewsManager } from '@server/lib/views/video-views-manager' + +export class ViewersObserversBuilder { + + constructor (private readonly meter: Meter) { + + } + + buildObservers () { + this.meter.createObservableGauge('peertube_viewers_total', { + description: 'Total viewers on the instance' + }).addCallback(observableResult => { + for (const viewerScope of [ 'local', 'remote' ] as ViewerScope[]) { + for (const videoScope of [ 'local', 'remote' ] as VideoScope[]) { + const result = VideoViewsManager.Instance.getTotalViewers({ viewerScope, videoScope }) + + observableResult.observe(result, { viewerOrigin: viewerScope, videoOrigin: videoScope }) + } + } + }) + } +} diff --git a/server/lib/opentelemetry/metrics.ts b/server/lib/opentelemetry/metrics.ts index 149f421be..ffe493670 100644 --- a/server/lib/opentelemetry/metrics.ts +++ b/server/lib/opentelemetry/metrics.ts @@ -4,7 +4,13 @@ import { PrometheusExporter } from '@opentelemetry/exporter-prometheus' import { MeterProvider } from '@opentelemetry/sdk-metrics-base' import { logger } from '@server/helpers/logger' import { CONFIG } from '@server/initializers/config' -import { JobQueueObserversBuilder, NodeJSObserversBuilder, StatsObserversBuilder } from './metric-helpers' +import { + JobQueueObserversBuilder, + LivesObserversBuilder, + NodeJSObserversBuilder, + StatsObserversBuilder, + ViewersObserversBuilder +} from './metric-helpers' class OpenTelemetryMetrics { @@ -53,6 +59,12 @@ class OpenTelemetryMetrics { const statsObserversBuilder = new StatsObserversBuilder(this.meter) statsObserversBuilder.buildObservers() + + const livesObserversBuilder = new LivesObserversBuilder(this.meter) + livesObserversBuilder.buildObservers() + + const viewersObserversBuilder = new ViewersObserversBuilder(this.meter) + viewersObserversBuilder.buildObservers() } private buildRequestObserver () { -- cgit v1.2.3