mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-05-23 17:19:37 +02:00
* [web] refactor startup sequence The primary objective here is to call loadGlobalBlobs() only once. But to get there, we need to reorder things and add extra try/catch sections to ensure we are not letting the global uncaughtException handler catch startup errors. Co-authored-by: Antoine Clausse <antoine.clausse@overleaf.com> * [web] add metrics for startup steps Co-authored-by: Antoine Clausse <antoine.clausse@overleaf.com> --------- Co-authored-by: Jakob Ackermann <jakob.ackermann@overleaf.com> GitOrigin-RevId: c73edea02516e919d55b896588dcd1862835fedf
overleaf/metrics-module
Wrappers the prom-client npm module to provide Prometheus metrics at /metrics.
Use:
// Metrics must be initialized before importing anything else
require('@overleaf/metrics/initialize')
const express = require('express')
const metrics = require('@overleaf/metrics')
const app = express()
metrics.injectMetricsRoute(app)
Request logging can be enabled:
const logger = require('@overleaf/logger')
...
app.use(metrics.http.monitor(logger))
The metrics module can be configured through the following environment variables:
DEBUG_METRICS- enables display of debugging messages to the console.GCP_OPENTELEMETRY- enables OpenTelemetry tracing for GCPJAEGER_OPENTELEMETRY- enables OpenTelemetry tracing for Jaeger (in the dev environment)METRICS_APP_NAME- the app label for metrics and spansMETRICS_COMPRESSION_LEVEL- sets the compression level for/metricsSTACKDRIVER_LOGGING- toggles the request logging formatUV_THREADPOOL_SIZE- sets the libuv thread pool size