Message queuing is a one-way communication style that provides asynchronous interaction between systems. As this chapter continues to describe how message queues work, the benefits will become clear. Some background on the request-response message exchange pattern will shed light on how RabbitMQ works.
The request-response message exchange pattern
There are many types of message exchange patterns, but the request-response style is the most common. A system, acting as a client, interacts with another remote system, which is acting as a server. The client sends a request for data, and the server responds to the request, as shown in the following diagram:
data:image/s3,"s3://crabby-images/258dd/258dd3e0d740d7419a0d6cdcfbf6818a121c2bad" alt=""
The request-response style is used when the client must have an immediate response or wants the service to complete a task without delay, such as being placed on hold when calling a restaurant to reserve a table:
data:image/s3,"s3://crabby-images/c7643/c7643d81201fc1dd0b9cd5c90c284721224cb1dc" alt=""