multiconsumer-kue
Version:
A multi-consumer queue on top of Kue
67 lines (42 loc) • 1.78 kB
Markdown
MultiConsumer Kue
===================
A [multi-consumer queue](https://www.npmjs.com/package/multiconsumer-queue) implementation using [Kue](https://www.npmjs.com/package/kue).
## Installation
```
npm install --save multiconsumer-kue
```
## Usage examples
```typescript
import * as kue from "kue"
import * as redis from "redis"
import {MultiConsumerKue} from "multiconsumer-kue"
const bus = MultiConsumerKue(kue.createQueue(), () => redis.createClient())
// Process "my-topic" for logging
bus.topic("my-topic").process("log", (job, cb) => {
console.log("got new job in topic \"my-topic\" with data", job.data)
cb()
})
// Save all "my-topic" messages to database
bus.topic("my-topic").process("save", (job, cb) => {
// here we're going to save all messages from "my-topic" to database
cb()
})
bus.topic("my-topic").add("Hello World!")
```
NOTE: Wrapper implementation is not removing consumer groups from `RedisLiveSet` so once you're
not interested anymore for processing topic messages for specific `groupId` -
you must remove that group and tasks manually
Group can be removed using `MultiConsumerQueueImpl.removeGroup()` method:
```typescript
const bus = MultiConsumerKue(...)
// deploy this to your servers to stop collecting tasks
bus.topic("my-topic").removeGroup("old-process-group")
```
You will still have to manually remove tasks already added for that group, or maybe those may expire,
this depends on how source `NamedQueue` is implemented.
## Contribute
> Perfection is Achieved Not When There Is Nothing More to Add,
> But When There Is Nothing Left to Take Away
Fork, Contribute, Push, Create pull request, Thanks.
## License
All code in this repository is licensed under the Apache License, Version 2.0. See [LICENCE](./LICENSE).