The distributed nature of cloud applications requires a messaging infrastructure that connects the components and services, ideally in a loosely coupled manner in order to maximize scalability. Asynchronous messaging is widely used, and provides many benefits, but also brings challenges such as the ordering of messages, poison message management, idempotency, and more.
Enable multiple concurrent consumers to process messages received on the same messaging channel.
Break down a task that performs complex processing into a series of separate elements that can be reused.
Prioritize requests sent to services so that requests with a higher priority are received and processed more quickly than those with a lower priority.
Use a queue that acts as a buffer between a task and a service that it invokes in order to smooth intermittent heavy loads.
Coordinate a set of actions across a distributed set of services and other remote resources.