overleaf/libraries/metrics
Christopher Hoskin 5f69488f67 Merge pull request #12369 from overleaf/csh-issue-4497-bump-profiler
Bump @google-cloud/profiler from 4.1.3 to 5.0.4

GitOrigin-RevId: 2426be7f50f91c8a67430f1097a9d97412178873
2023-04-06 08:02:49 +00:00
..
.circleci Fix startup crash 2020-09-17 10:30:25 -04:00
test Merge pull request #11680 from overleaf/em-mongo-pool-monitoring 2023-02-09 14:34:35 +00:00
.dockerignore Merge pull request #5724 from overleaf/jpa-lean-docker-build 2021-11-09 09:04:02 +00:00
.gitignore [misc] prepare for monorepo 2021-07-27 16:33:33 +01:00
.npmignore Add .npmignore to avoid publishing config files 2020-09-17 10:44:24 -04:00
.nvmrc Merge pull request #9819 from overleaf/bg-node-upgrade 2022-10-04 08:02:41 +00:00
buildscript.txt Merge pull request #9819 from overleaf/bg-node-upgrade 2022-10-04 08:02:41 +00:00
CHANGELOG.md Merge pull request #10144 from overleaf/ii-metrics-api-patch-opts-arg 2022-10-28 08:04:43 +00:00
event_loop.js Merge pull request #6120 from overleaf/jpa-same-linting-packages 2021-12-17 09:03:06 +00:00
http.js Merge pull request #7905 from overleaf/em-request-logging 2022-05-17 08:05:19 +00:00
index.js Merge pull request #11680 from overleaf/em-mongo-pool-monitoring 2023-02-09 14:34:35 +00:00
LICENSE Create LICENSE 2014-09-08 09:19:39 +01:00
memory.js Merge pull request #7906 from overleaf/em-downgrade-logs 2022-05-17 08:05:26 +00:00
mongodb.js Merge pull request #11680 from overleaf/em-mongo-pool-monitoring 2023-02-09 14:34:35 +00:00
open_sockets.js Merge pull request #6120 from overleaf/jpa-same-linting-packages 2021-12-17 09:03:06 +00:00
package.json Merge pull request #12369 from overleaf/csh-issue-4497-bump-profiler 2023-04-06 08:02:49 +00:00
prom_wrapper.js Merge pull request #11679 from overleaf/em-upgrade-prom-client 2023-02-09 14:34:28 +00:00
README.md Merge pull request #5246 from overleaf/bg-upgrade-logger-in-all-libraries 2021-10-29 08:03:14 +00:00
timeAsyncMethod.js Merge pull request #7906 from overleaf/em-downgrade-logs 2022-05-17 08:05:26 +00:00
tracing.js Merge pull request #10279 from overleaf/jpa-tracing-optimizations 2022-11-04 09:05:00 +00:00
uv_threadpool_size.js Merge pull request #6120 from overleaf/jpa-same-linting-packages 2021-12-17 09:03:06 +00:00

overleaf/metrics-module

Wrappers the prom-client npm module to provide Prometheus metrics at /metrics.

Use:

const metrics = require('@overleaf/metrics')
metrics.initialize('myapp')

const express = require('express')
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.
  • ENABLE_TRACE_AGENT - enables @google-cloud/trace-agent on Google Cloud
  • ENABLE_DEBUG_AGENT - enables @google-cloud/debug-agent on Google Cloud
  • ENABLE_PROFILE_AGENT - enables @google-cloud/profiler on Google Cloud
  • METRICS_COMPRESSION_LEVEL - sets the compression level for /metrics
  • STACKDRIVER_LOGGING - toggles the request logging format
  • UV_THREADPOOL_SIZE - sets the libuv thread pool size