busy

Detect if event loop is busy.

The idea is not new, implementation probably too. I just saw this https://github.com/lloyd/node-toobusy and found it useful. This projects does pretty the same but in pure javascript.

  • Log how busy is the loop
  • Stop accepting new tasks
var busy = require('busy'),
    express = require('express');

var app = express();

var busyCheck = busy(function(amount) {
    console.log('Loop was busy for', amount, 'ms');
});

// middleware which blocks requests when we're too busy
app.use(function(req, res, next) {
    if (busyCheck.state) {
        res.send(503, "I'm busy right now, sorry.");
    } else {
        next();
    }
});

app.get('/', function(req, res) {
    // processing the request requires some work!
    var i = 0;
    while (i < 1e5) i++;
    res.send("I counted to " + i);
});

var server = app.listen(3000);

process.on('SIGINT', function() {
    server.close();
    // calling .stop allows your process to exit normally
    busyCheck.stop();
    process.exit();
});

Optional options:

- `tolerance` in ms, default is 100ms
- `interval` how often to check the state in ms, default is 50ms

Optional callback is called every time the event loop was busy for longer amount of time than defined in tolerance. Passed value is amount of ms the loop was blocked for.

var busyCheck = busy();

busyCheck.blocked; // Is true if by the last check, tolerance was exceeded
busyCheck.blockedFor; // Number in ms the loop was blocked for, during the last check

busyCheck.stop(); // Stop doing checks