2017-07-17 05:35:33 +00:00
|
|
|
import http from 'http';
|
2017-07-18 04:58:58 +00:00
|
|
|
import { register, collectDefaultMetrics } from 'prom-client';
|
2017-07-17 05:35:33 +00:00
|
|
|
import { parse as parseURL } from 'url';
|
|
|
|
|
|
|
|
const LOGGER = require('@calzoneman/jsli')('prometheus-server');
|
|
|
|
|
|
|
|
let server = null;
|
2017-07-18 04:58:58 +00:00
|
|
|
let defaultMetricsTimer = null;
|
2017-07-17 05:35:33 +00:00
|
|
|
|
|
|
|
export function init(prometheusConfig) {
|
|
|
|
if (server !== null) {
|
|
|
|
LOGGER.error('init() called but server is already initialized! %s',
|
|
|
|
new Error().stack);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-07-18 04:58:58 +00:00
|
|
|
defaultMetricsTimer = collectDefaultMetrics();
|
|
|
|
|
2017-07-17 05:35:33 +00:00
|
|
|
server = http.createServer((req, res) => {
|
|
|
|
if (req.method !== 'GET'
|
|
|
|
|| parseURL(req.url).pathname !== prometheusConfig.getPath()) {
|
|
|
|
res.writeHead(400, { 'Content-Type': 'text/plain' });
|
|
|
|
res.end('Bad Request');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
res.writeHead(200, {
|
|
|
|
'Content-Type': register.contentType
|
|
|
|
});
|
|
|
|
res.end(register.metrics());
|
|
|
|
});
|
|
|
|
|
|
|
|
server.on('error', error => {
|
|
|
|
LOGGER.error('Server error: %s', error.stack);
|
|
|
|
});
|
|
|
|
|
|
|
|
server.once('listening', () => {
|
|
|
|
LOGGER.info('Prometheus metrics reporter listening on %s:%s',
|
|
|
|
prometheusConfig.getHost(),
|
|
|
|
prometheusConfig.getPort());
|
|
|
|
});
|
|
|
|
|
|
|
|
server.listen(prometheusConfig.getPort(), prometheusConfig.getHost());
|
|
|
|
return { once: server.once.bind(server) };
|
|
|
|
}
|
|
|
|
|
|
|
|
export function shutdown() {
|
|
|
|
server.close();
|
|
|
|
server = null;
|
2017-07-18 04:58:58 +00:00
|
|
|
clearInterval(defaultMetricsTimer);
|
|
|
|
defaultMetricsTimer = null;
|
2017-07-17 05:35:33 +00:00
|
|
|
}
|