Broker pattern explained

The broker pattern is an architectural pattern that can be used to structure distributed software systems with decoupled components that interact by remote procedure calls. A broker component is responsible for coordinating communication, such as forwarding requests, as well as transmitting results and exceptions.[1]

Definition

The broker pattern is an architecture pattern that involves the use of an intermediary software entity, called a "broker", to facilitate communication between two or more software components. The broker acts as a "middleman" between the components, allowing them to communicate without being aware of each other's existence.

In the broker pattern, the broker is responsible for receiving messages from one component and forwarding them to the appropriate recipient. The components that communicate through the broker are known as servers or clients. The broker may also perform additional tasks, such as filtering, modifying messages, ensuring a quality of service (QoS) (e.g. 0 for "at most once"), security, or providing additional services to the software components.

The broker pattern allows the components to remain decoupled and focused on their own responsibilities, while still being able to communicate and collaborate with other components in the system. It can also be used to reduce the number of dependencies between components, making the system more flexible and easier to maintain.

Terminology

Broker

Server

Client

Advantages

Source:[2]

Disadvantages

Real-life implementation of the pattern

Confusions around the pattern

The broker pattern and publish–subscribe pattern have some similarities and are sometimes confused.[3] Nevertheless, when it comes to the representation, there are some core differences:

Notes and References

  1. Web site: Solution: Use a Broker - Pattern-Oriented Software Architecture For Dummies [Book]]. www.oreilly.com. 26 March 2023.
  2. The Broker Architectural Framework. Michael. Stal. 1 January 1995. 26 March 2023. www.academia.edu.
  3. Web site: MQTT Client and Broker and MQTT Server Connection Establishment Explained - MQTT Essentials: Part 3. The HiveMQ. Team. www.hivemq.com. 26 March 2023.