mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-29 03:13:41 -05:00
8db30020ae
If we monitor with setImmediate, we miss big blocking loops. For example, suppose we have 1000 1ms loops then a single bad 1000ms loop. setImmediate will only be called at the right time 1/1000 of the time (it has to be the loop just before the bad one). So this monitoring method gives a good average if the std dev is low, but doesn't pick up spikes. Instead, we can monitor the skew from the expected time between setIntervals. In the case above, with a setInterval for 1000ms, we will pick up a skew proportional to the amount of time that it overlaps the bad loop. So 50% change of picking up skew > 500ms, and thus getting a good sense of any spikes.
16 lines
473 B
CoffeeScript
16 lines
473 B
CoffeeScript
module.exports = EventLoopMonitor =
|
|
monitor: (logger, interval = 1000, log_threshold = 100) ->
|
|
Metrics = require "./metrics"
|
|
|
|
previous = Date.now()
|
|
intervalId = setInterval () ->
|
|
now = Date.now()
|
|
offset = now - previous - interval
|
|
if offset > log_threshold
|
|
logger.warn {offset: offset}, "slow event loop"
|
|
previous = now
|
|
Metrics.timing("event-loop-millsec", offset)
|
|
, interval
|
|
|
|
Metrics.registerDestructor () ->
|
|
clearInterval(intervalId)
|