@emartech/rabbitmq-worker
BaseWorker
Automatically logs worker failures with context and elapsed time on success run.
Methods
retry(message, errorCode)
Re-queues the currently processed message for retry.
queueWorker(workerId, options)
Starts a new worker with the given worker id.
To set required keys in the options, set requiredKeys
in the worker's configuration as an array.
Example
const { BaseWorker } = require('@emartech/rabbitmq-worker');
class MyWorker extends BaseWorker {
async run(options) {
console.log(options);
console.log(this.config.foo);
if (errorHappened) {
this.retry('Something happened', 400);
}
this.queueWorker('NextWorker', { newVar: 'foo' });
}
}
MyWorker
.create('my-worker-log-namespace')
.execute({foo: 'bar'}, { option: 'foo' });
Ignition
Starts the given type of worker to consume a RabbitMQ queue.
A sample worker starting script my-worker.js
:
const { Ignition } = require('@emartech/rabbitmq-worker');
const workerPool = require('./worker-pool');
Ignition.create(workerPool).start('MyWorker');
RabbitMq
See @emartech/rabbitmq-client
for more information.
Configuration
@emartech/rabbitmq-worker
uses node-config
`package for configuration.
Required configuration example
{
"RabbitMQ": "rabbitmq://connection",
"Workers": {
"MyWorker": {
"queueName": "my-worker",
"concurrency": 3,
"prefetchCount": 10,
"autoNackTime": 60000,
"customConfigVar": "foo"
}
}
}
Worker pool example
{
MyWorker: require('./workers/my-worker')
}