1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/lib/metrics.js

51 lines
1.5 KiB
JavaScript
Raw Normal View History

2016-12-04 14:09:37 +01:00
'use strict';
const events = require('./events');
const {
FEATURE_CREATED,
FEATURE_UPDATED,
FEATURE_ARCHIVED,
FEATURE_REVIVED,
} = require('./event-type');
exports.startMonitoring = (enable, eventBus, eventStore) => {
if (!enable) {
return;
}
const client = require('prom-client');
2017-08-23 11:27:58 +02:00
const gcStats = require('prometheus-gc-stats');
2016-12-04 14:09:37 +01:00
2017-06-28 14:21:05 +02:00
client.collectDefaultMetrics();
2017-08-23 11:27:58 +02:00
gcStats()();
2017-06-28 14:21:05 +02:00
const requestDuration = new client.Summary({
name: 'http_request_duration_milliseconds',
help: 'App response time',
labelNames: ['path', 'method', 'status'],
percentiles: [0.1, 0.5, 0.9, 0.99],
});
const featureToggleUpdateTotal = new client.Counter({
name: 'feature_toggle_update_total',
help: 'Number of times a toggle has been updated',
labelNames: ['toggle'],
});
2016-12-04 14:09:37 +01:00
eventBus.on(events.REQUEST_TIME, ({ path, method, time, statusCode }) => {
requestDuration.labels(path, method, statusCode).observe(time);
});
eventStore.on(FEATURE_CREATED, ({ data }) => {
featureToggleUpdateTotal.labels(data.name).inc();
});
eventStore.on(FEATURE_UPDATED, ({ data }) => {
featureToggleUpdateTotal.labels(data.name).inc();
});
eventStore.on(FEATURE_ARCHIVED, ({ data }) => {
featureToggleUpdateTotal.labels(data.name).inc();
});
eventStore.on(FEATURE_REVIVED, ({ data }) => {
featureToggleUpdateTotal.labels(data.name).inc();
});
2016-12-04 14:09:37 +01:00
};