Simple async batch with concurrency control and progress reporting.
This is a Node.js module available through the
npm registry. Installation is done using the
npm install command:
$ npm install batchvar Batch = require('batch')Create a new Batch, optionally passing an options object and/or a list of
functions (fns) to queue.
The options object may contain the following keys:
concurrency: set the defaultconcurrencyfor the Batch, which can be changed usingbatch.concurrency(n).throws: set the defaultthrowsfor the Batch, which can be changed usingbatch.throws(throws).
Set concurrency to n.
Execute all queued functions in parallel, executing cb(err, results).
Queue a function.
Set whether Batch will or will not throw up.
Contains the "job" index, response value, duration information, and completion data.
{ index: 1,
  value: 'bar',
  pending: 2,
  total: 3,
  complete: 2,
  percent: 66,
  start: Thu Oct 04 2012 12:25:53 GMT-0700 (PDT),
  end: Thu Oct 04 2012 12:25:53 GMT-0700 (PDT),
  duration: 0 }
var Batch = require('batch')
  , batch = new Batch;
batch.concurrency(4);
ids.forEach(function(id){
  batch.push(function(done){
    User.get(id, done);
  });
});
batch.on('progress', function(e){
});
batch.end(function(err, users){
});