amqp-delegate
A very simplistic, but performant, remote worker system that uses AMQP to coordinate jobs.
data:image/s3,"s3://crabby-images/f6785/f6785e906c527c3f47f333a9b3b0bd66c4460037" alt="Greenkeeper badge"
branch | status | coverage | notes |
---|
develop | data:image/s3,"s3://crabby-images/bc754/bc754dd8e87bd52dc9f484dab97f27932f3cf887" alt="CircleCI" | data:image/s3,"s3://crabby-images/9d76b/9d76bf6fa5a3cbe7f56fcb8a1505e57a95b7e2b6" alt="codecov" | Work in progress |
master | data:image/s3,"s3://crabby-images/ce339/ce339961e8dff1243e0967dbc6ef926f8e73776f" alt="CircleCI" | data:image/s3,"s3://crabby-images/d7fd6/d7fd616995a106528b8e41f367f7973fd4212f1d" alt="codecov" | Latest stable release |
npm install amqp-delegate
Worker
const { makeWorker } = require('amqp-delegate')
const worker = makeWorker({
url: <the url of the amqp server> - defaults to ampq://localhost,
name: <the name of the worker> — required,
task: <any pure async function> — required
onError: err => { // optional
console.error('A connection error happened', err) // or do something clever
}
onClose: () => { // optional
console.log('The connection has closed.') // or do something clever
}
})
// start it
worker.start().then(() => {
console.log('worker', worker.name, 'started')
})
// stop it
worker.stop().then(() => {
console.log('worker', worker.name, 'stopped')
})
Delegator
const { makeDelegator } = require('amqp-delegate')
const delegator = makeWorker({
url: <the url of the amqp server> - defaults to ampq://localhost,
onError: err => { // optional
console.error('A connection error happened', err) // or do something clever
}
onClose: () => { // optional
console.log('The connection has closed.') // or do something clever
}
})
delegator
.start()
.then(() => {
delegator.invoke('worker name', ...params)
console.log('job name', result)
})
.catch(err => {
console.error('worker name', err)
})
A concrete example
The worker
const { makeWorker } = require('amqp-delegate')
const task = (a, b) =>
new Promise(resolve => setTimeout(() => resolve(a + b), 10))
const worker = makeWorker({
name: 'adder',
task
})
worker
.start()
.then(() => {
process.on('SIGINT', () => {
worker
.stop()
.then(() => {
process.exit(0)
})
})
})
.catch(err => {
console.error('caught', err)
})
The delegator
const { makeDelegator } = require('amqp-delegate')
const delegator = makeDelegator()
delegator
.start()
.then(() => delegator.invoke('adder', 10, 15))
.then(result => {
console.log('result', result)
})
.catch(err => {
console.error('caught', err)
})
Development
Prerequisites
Initialisation
npm install
To Start the queue server for integration testing.
docker-compose up -d
Runs Rabbit MQ.
Test it
npm test
— runs the unit tests (does not need rabbitmq)npm run test:unit:cov
— runs the unit tests with code coverage (does not need rabbitmq)npm run test:integration
— runs the integration tests (needs rabbitmq)
note Node 11.7+ breaks nyc
and mocha
— see https://github.com/nodejs/node/issues/25650
Lint it
npm run lint
Contributing
Please see the contributing notes.