RediBox Job
data:image/s3,"s3://crabby-images/fa9d1/fa9d1813ea3294b110084422e920aa1d9c6ff836" alt="Coverage Status"
data:image/s3,"s3://crabby-images/e9c59/e9c59211c2ddc95b15e20931de328aa899bea0b2" alt="Downloads"
data:image/s3,"s3://crabby-images/5784b/5784b7f49c7219b7279d73fe1aa216b0f81fa8d4" alt="npm version"
data:image/s3,"s3://crabby-images/9718b/9718b29ab507cfd35be48c30fc9c0eb4066d0b49" alt="dependencies"
data:image/s3,"s3://crabby-images/40721/407210882ffd8a382ce866ba822eab4be5043872" alt="build"
data:image/s3,"s3://crabby-images/f9eb6/f9eb67266500fba1835f20216afa58f968848485" alt="License"
The RediBox Job hook allows code to be run & distributed across many servers, whilst being highly configurable. Works well with the Schedule hook.
Features
- Poll free design.
- Optional job TTL.
- Optional job retries.
- Optional job uniqueness.
- Queue rate limiting - X per X seconds.
- Standalone, Sentinel or Clustered Redis confgurations supported.
- Stalling prevention - gracefully resumes from shutdowns / crashes.
- Optional job statuses / progress sent via pubsub to the job creator.
- Flexible job runner functions - your functions can return a promise or just a synchronous result.
- Chain together jobs accross multiple queues and pass individual results onto the next job.
- Cancel the relay at any point on any of the jobs.
- Throttle stages of the relay by jumping to a throttled queue.
- Single queue job handler function or individual handlers per job using dot notated paths to global functions.
Coming in v2
- Capped history lists of jobs.
- Queue stats (process times, average job waiting time etc).
- Job tagging. Tag a job and track it throughout it’s lifetime.
- JSON API via redibox/api.
- Responsive UI via redibox/ui.
- Delayed / scheduled jobs via redibox/schedule (v2).
Installation
First ensure you have RediBox installed.
Install Job via npm/yarn:
npm install redibox-hook-job --save
yarn add redibox-hook-job
Usage
RediBox.hooks.job.create('my-queue', {
runs: 'sails.hooks.myhook.runJobFoo', // dot notated path to a globally accessible function
data: {
foo: 'bar',
}
});
// With Sails hook
Job.create('my-queue', {
runs: 'sails.hooks.myhook.runJobBar', // dot notated path to a globally accessible function
data: {
foo: 'bar',
}
});
Documentation
License
MIT