Message broker explained

A message broker (also known as an integration broker or interface engine[1]) is an intermediary computer program module that translates a message from the formal messaging protocol of the sender to the formal messaging protocol of the receiver. Message brokers are elements in telecommunication or computer networks where software applications communicate by exchanging formally-defined messages. Message brokers are a building block of message-oriented middleware (MOM) but are typically not a replacement for traditional middleware like MOM and remote procedure call (RPC).[2] [3]

Overview

A message broker is an architectural pattern for message validation, transformation, and routing. It mediates communication among applications, minimizing the mutual awareness that applications should have of each other in order to be able to exchange messages, effectively implementing decoupling.[4]

Purpose

The primary purpose of a broker is to take incoming messages from applications and perform some action on them. Message brokers can decouple end-points, meet specific non-functional requirements, and facilitate reuse of intermediary functions. For example, a message broker may be used to manage a workload queue or message queue for multiple receivers, providing reliable storage, guaranteed message delivery and perhaps transaction management.

Life cycle

The following represent other examples of actions that might be handled by the broker:

Message brokers are generally based on one of two fundamental architectures: hub-and-spoke and message bus. In the first, a central server acts as the mechanism that provides integration services, whereas with the latter, the message broker is a communication backbone or distributed service that acts on the bus. Additionally, a more scalable multi-hub approach can be used to integrate multiple brokers.

Real-time Semantics

Message brokers that are purpose built to achieve time-bounded communications with end-to-end predictability allow for the development of real-time systems that require execution predictability. Frequently systems with real-time requirements involve interaction with the real world (robotics, vehicle automation, Software-defined radio, et al.)

The Object Management Group Real-time CORBA specification provides a theoretical foundation for predictable communications technologies by levying the following requirements:

For the purposes of this specification, "end-to-end predictability" of timeliness in a fixed priority CORBA system is defined to mean:• respecting thread priorities between client and server for resolving resource contention during the processing of CORBA invocations;

• bounding the duration of thread priority inversions during end-to-end processing;

• bounding the latencies of operation invocations

List of message broker software

See also

Notes and References

  1. Web site: IB (integration broker) . IT Glossary . Gartner, Inc . 17 May 2018.
  2. Book: https://books.google.com/books?id=1IuZBQAAQBAJ&pg=PA117 . Integration Technologies . Guide to Cloud Computing for Business and Technology Managers: From Distributed Computing to Cloudware Applications . Kale, V. . CRC Press . 107–134 . 2014 . 9781482219227 . 17 May 2018.
  3. Book: https://books.google.com/books?id=2EonCgAAQBAJ&pg=PA71 . Integration Brokers and Web Services . Web Services Business Strategies and Architectures . Samtani, G. . Sadhwani, D. . Clark, M. . Fletcher, P. . Hanson, J.J. . etal . Apress . 71–84 . 2013 . 9781430253563 . 17 May 2018.
  4. Book: Asynchronous Processing . Web Scalability for Startup Engineers . Ejsmont, A. . McGraw Hill Professional . 275–276 . 2015 . 9780071843669.
  5. Book: Rotaru . Mihai . Olariu . Florentin . Onica . Emanuel . Rivière . Etienne . Proceedings of the 18th ACM/IFIP/USENIX Middleware Conference: Industrial Track . Reliable messaging to millions of users with migratorydata . 1 . December 2017 . 1–7 . 10.1145/3154448.3154449. 1712.09876 . 9781450352000 . 35552786 .