AMQP (RabbitMQ)
AMQP is an open standard application layer protocol for message-oriented communication, i.e. implemented by RabbitMQ message-broker.
RabbitMQ is the most widely deployed open source message broker. With tens of thousands of users, it is one of the most popular open source message brokers. From T-Mobile to Runtastic, it is used worldwide at small startups and large enterprises. RabbitMQ is lightweight and easy to deploy on premises and in the cloud. It supports multiple messaging protocols and can be deployed in distributed and federated configurations to meet high-scale, high-availability requirements.
Installation
Before the usage remember to install required packages.
Overview
The options
property is specific to the chosen transport layer. AMQP exposes the following properties:
Attribute
description
host
Host address of the RabbitMQ server
queue
Queue name which your microservice will listen to
queueOptions
prefetchCount
Sets the prefetch count for the channel
expectAck
If true
, manual acknowledgment mode is enabled
timeout
Timeout for RPC-like communication. Defaults to 120 seconds
Acknowledgement
To make sure an event is never lost, RabbitMQ supports message acknowledgements. An acknowledgement is sent back by the consumer to tell RabbitMQ that a particular message has been received, processed and that RabbitMQ is free to delete it. If a consumer dies (its channel is closed, connection is closed, or TCP connection is lost) without sending an ack, RabbitMQ will understand that a message wasn't processed fully and will re-queue it.
To enable manual acknowledgment mode, set the expectAck
property to true
.
When manual acknowledgements are turned on, we must send a proper acknowledgement from the worker to signal that we are done with a task.
@marblejs/messaging v3.3 introduces three handy functions for event acknowledgement: ackEvent
, nackEvent
and nackAndResendEvent
. While the behavior of the first function is obvious, the second function will reject the event immediately, where the third one will try to resend the event again to the origin channel. You have to pass EffectContext
first and the incoming event object to which acknowledgement will be made. Since all three functions are doing an asynchronous side effect, you have to call it explicitly.
It is in the responsibility of developer to nack messages. If the consumer won't nack the message, it will hang up and wait for (non-)acknowledgement signal till the default transport layer timeout or the connection closing signal. After this time the event will be automatically rejected.
If the microservice (consumer) is in acknowledgement mode (expectAck: true
), all outgoing messages that target the same origin queue won't be emitted to prevent accidental consumer blocking. If you would like to emit another event, eg. as a confirmation response to the origin queue with acknowledgement mode enabled, you have to emit the event explicitly by connected messaging client.
Last updated