Mulitcast Strategy for MQueue
Broadcast a message to multiple different
MQueue
queue backends simultaneously, with the same interface. Publish to
amqplib,
azure-service-bus,
rhea, and
sqs with one call.
npm install --save @mqueue/queue @mqueue/multicast
const outgoingQueue = new MQueue.Outgoing(
new MulticastQueue.Outgoing([
await AmqplibOutgoingQueue.connect("amqp://rabbitmq:5271", "queue-name"),
await AmqplibOutgoingQueue.connect("amqp://rabbitmq:5272", "queue-name2"),
]),
);
outgoingQueue.sendMessage({
headers: {
"Account-ID": "123",
},
body: "...",
});
const incomingQueue = new MQueue.Incoming(
new MulticastQueue.Incoming([
await AmqplibIncomingQueue.connect("amqp://rabbitmq:5271", "queue-name"),
await AmqplibIncomingQueue.connect("amqp://rabbitmq:5272", "queue-name2"),
]),
);
await incomingQueue.consume(async (payload) => {
const topicOrQueueName = payload.transport.name;
const headers = payload.message.headers;
const data = await payload.message.json();
await payload.accept();
});
Filtering & Randomisation
import MQueue from "@mqueue/queue";
import { MulticastQueue } from "@mqueue/multicast";
const filter = (adapters) => [adapters[randomInt(adapters.length)]];
cosnt filter = (adapters, message) => {
return message.headers.example === "something" ? adapter[0] : adapter;
};
const outgoingQueue = new MQueue.Outgoing(
new MulticastQueue.Outgoing([
await AmqplibOutgoingQueue.connect("amqp://rabbitmq:5271", "queue-name"),
await AmqplibOutgoingQueue.connect("amqp://rabbitmq:5272", "queue-name2"),
]),
{ filter },
);
const incomingQueue = new MQueue.Incoming(
new MulticastQueue.Incoming([
await AmqplibIncomingQueue.connect("amqp://rabbitmq:5271", "queue-name"),
await AmqplibIncomingQueue.connect("amqp://rabbitmq:5272", "queue-name2"),
]),
{ filter },
);
await incomingQueue.consume(async (payload) => {
const topicOrQueueName = payload.transport.name;
const headers = payload.message.headers;
const data = await payload.message.json();
await payload.accept();
});
License
MIT © Dom Webber