1.0.0 • Published 4 years ago

sails-hook-bull v1.0.0

Weekly downloads
4
License
MIT
Repository
github
Last release
4 years ago

sails-hook-bull

Sails.js hook to use bull package for handling distributed jobs and messages.

Installation

Install it via npm:

npm install sails-hook-bull --save

or

yarn add sails-hook-bull

Requirement: Redis version greater than or equal to 2.8.18 is required.

Configuration

You can set some parameters in config/bull.js to overrides defaults options for all queues.

module.exports.bull = {
    redis: {
        port: 6379,
        host: '127.0.0.1',
        db: 0,
        password: ''
    }
}

See bull.queue for more information.

Examples

Bull queue definition in api/queues/firstQueue.js

module.exports = {
  queueName: 'first-queue',
  // if redis already defined as an object, url will be ignored
  url: 'redis://127.0.0.1:6379',
  opts: {
    limiter: {
        max: 1000,
        duration: 5000
    }
  },
  process: async job => {
    return doSomething(job.data);
  }
};

You can define queues with options:

module.exports = {
  queueName: 'my-queue',
  process: {
    name: 'my-process',
    concurrency: 1,
    processor: (job, done) => {
      // do something...
      done();
    }
  }
};

Adding jobs to a queue:

// api/controllers/someController.js
module.exports = {
  someAction: function(req, res) {
    sails.hooks.bull.firstQueue.add({
        foo: 'bar'
    })
  }
};

License

MIT