@universal-packages/redis-pubsub
v1.0.4
Published
Redis identifiable messages pubsub system
Downloads
8
Readme
Redis Pubsub
Redis identifiable messages pubsub system for redis. This is useful to communicate between processes or even between servers or containers. You can already do this with just redis pub sub system but this package enhance that a little, for example you can subscribe to a channel but ignore messages if they are being published by itself, also it is being shared some useful metadata with every message so you can act more robustly with each message.
Install
npm install @universal-packages/redis-pubsub
npm install redis
RedisPubSub
An instance of RedisPubSub
allows you to start publishing messages to any channel and any other RedisPubSub
instance connected to the same redis server will be able to receive them if they are subcribed.
import { RedisPubSub } from '@universal-packages/universal-redis-pubsub'
const redisPubSub = new RedisPubSub({ identifier: 'app' })
await redisPubSub.connect()
await redisPubSub.publish('job', { make: 'sandwich' })
redisPubSub.on('job-done', (message) => {
console.log('thanks')
})
/// In other process
const redisPubSub = new RedisPubSub({ identifier: 'job-processor' })
await redisPubSub.connect()
await redisPubSub.subscribe('job')
redisPubSub.on('job', (message) => {
const id = makeSandwich()
redisPubSub.publish('job-done', { sandwichId: id })
})
Options
RedisPubSub
takes the same options as the redis client.
Additionally takes the following ones:
client
RedisClient
If you already have a client working in your app you can pass the instance here to not connect another client inside theRedisPubSub
instance only a new subscription instance will be handled inside.identifier
String
This can be used to identify who is sending messages to other instances, we do not want unsolicited publishing.ignoreSelfPublications
Boolean
default: true
Normally you don't want your current process to hear the same messages it is publishing but in case you want that for some reason set this tofalse
.
Instance methods
connect()
Connect the internal subscriptions client and the publish client in case it was not passed as option.
disconnect()
Disconnect the internal subscriptions client and the publish client in case it was not passed as option.
psubscribe(channel: string)
Subscribe the instance to a patter of channels, it will then emit to that pattern and to the exact channel for that a message was published.
await redisPubSub.psubscribe('channel*')
redisPubSub.on('channel*', (message) => {
// All publishing to any channel like 'channelA', 'channelB'
})
redisPubSub.on('channelA', (message) => {
// It also matches channel* but will just receive channelA messages
})
subscribe(channel: string)
Subscribe the instance to specific channel or channels.
await redisPubSub.subscribe('channelA')
redisPubSub.on('channel*', (message) => {
// Not triggered
})
redisPubSub.on('channelA', (message) => {
// It matches channelA so it will receive it
})
publish(channel: string, data: Object)
Publish to the specific channel.
await redisPubSub.publish('channelA', { data: 'things to share to channel A' })
Typescript
This library is developed in TypeScript and shipped fully typed.
Contributing
The development of this library happens in the open on GitHub, and we are grateful to the community for contributing bugfixes and improvements. Read below to learn how you can take part in improving this library.