This repository was archived by the owner on Dec 15, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
80 lines (68 loc) · 2.42 KB
/
index.js
File metadata and controls
80 lines (68 loc) · 2.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
var onHeaders = require('on-headers'),
exec = require('child_process').exec;
module.exports.eventLoopGauge = function(metrics) {
setInterval(function(metrics) {
var timer = metrics.createTimer('event_loop_delay');
setImmediate(timer.stop.bind(timer));
}.bind(null, metrics), 10000);
};
module.exports.fileDescriptorGauge = function(metrics) {
var recordConns = function(metrics) {
exec('ls -q /proc/' + process.pid + '/fd | wc -l', function(err, data) {
var count = Number(data);
if (!err && count) {
metrics.gauge('file_descriptors', count);
}
setTimeout(recordConns, 30000);
});
}.bind(null, metrics);
setTimeout(recordConns, 30000);
};
module.exports.nodeMemoryGauge = function(metrics) {
setInterval(function(metrics) {
var memoryUsage = process.memoryUsage();
metrics.gauge('memory.rss', memoryUsage.rss);
metrics.gauge('memory.heapTotal', memoryUsage.heapTotal);
metrics.gauge('memory.heapUsed', memoryUsage.heapUsed);
}.bind(null, metrics), 10000);
};
module.exports.nodeConnectionsGauge = function(metrics, server) {
var recordConns = function(metrics) {
server.getConnections(function(err, count) {
if (!err) {
metrics.gauge('connections', count);
}
setTimeout(recordConns, 1000);
});
}.bind(null, metrics);
setTimeout(recordConns, 1000);
};
module.exports.allGauges = function(metrics, server) {
module.exports.eventLoopGauge(metrics);
module.exports.fileDescriptorGauge(metrics);
module.exports.nodeMemoryGauge(metrics);
module.exports.nodeConnectionsGauge(metrics, server);
};
module.exports.requestStatsMiddleware = function(req, res, next) {
var startTimeHr = process.hrtime();
onHeaders(res, function() {
var diff = process.hrtime(startTimeHr),
time = diff[0] * 1000 + diff[1] * 1e-6;
req.metrics.increment('res_status.' + res.statusCode);
req.metrics.timing('res_time', time);
});
next();
};
module.exports.requestStatsByRouteMiddleware = function(req, res, next) {
var startTimeHr = process.hrtime();
onHeaders(res, function() {
var diff = process.hrtime(startTimeHr),
time = diff[0] * 1000 + diff[1] * 1e-6;
if (req.route && req.route.path) {
var safePath = req.route.path.replace(/\||:|"|'/g, '');
req.metrics.increment('route.' + safePath + '.status.' + res.statusCode);
req.metrics.timing('route.' + safePath + '.time', time);
}
});
next();
};