| Messaging Patterns Overview | |
data:image/s3,"s3://crabby-images/752e0/752e013ef03e279fdee3e3a05d0153e1a272a196" alt="" | Table of Contents |
Detailed table of contents.
|
data:image/s3,"s3://crabby-images/1abfd/1abfdfd0f0e3d93f0cc2fc8ea7b4e859acea2cc6" alt="" | Preface | |
data:image/s3,"s3://crabby-images/1abfd/1abfdfd0f0e3d93f0cc2fc8ea7b4e859acea2cc6" alt="" | Introduction | |
data:image/s3,"s3://crabby-images/1abfd/1abfdfd0f0e3d93f0cc2fc8ea7b4e859acea2cc6" alt="" | Solving Integration Problems using Patterns | |
Integration Styles |
data:image/s3,"s3://crabby-images/1abfd/1abfdfd0f0e3d93f0cc2fc8ea7b4e859acea2cc6" alt="" | Introduction to Integration Styles | |
data:image/s3,"s3://crabby-images/b3705/b37052e4c6d18ed67dca350ed93407d47174f9cf" alt="" | File Transfer | How can I integrate multiple applications so that they work together and can exchange information? |
data:image/s3,"s3://crabby-images/810fe/810fea5a1ef1ee81cb538b23ca5ddd7570bb967b" alt="" | Shared Database | How can I integrate multiple applications so that they work together and can exchange information? |
data:image/s3,"s3://crabby-images/53b22/53b22a1566dca3a81c34f479e54b42a1dfcbeab7" alt="" | Remote Procedure Invocation | How can I integrate multiple applications so that they work together and can exchange information? |
data:image/s3,"s3://crabby-images/0877b/0877b49761d593ff99f988036db4dca3544371f8" alt="" | Messaging | How can I integrate multiple applications so that they work together and can exchange information? |
Messaging Systems |
data:image/s3,"s3://crabby-images/0877b/0877b49761d593ff99f988036db4dca3544371f8" alt="" | Introduction to Messaging Systems | |
data:image/s3,"s3://crabby-images/0f69f/0f69f42a581284405f822218f696e8d592c37317" alt="" | Message Channel | How does one application communicate with another using messaging? |
data:image/s3,"s3://crabby-images/55d12/55d12b7d05d000b743b594053d39865850a870ed" alt="" | Message | How can two applications connected by a message channel exchange a piece of information? |
data:image/s3,"s3://crabby-images/cab11/cab11151f01ccd5aa834b856926ce3a9a64bb819" alt="" | Pipes and Filters |
How can we perform complex processing on a message while maintaining independence and flexibility?
|
data:image/s3,"s3://crabby-images/8e7c0/8e7c0acc67cbcd7298fc7a366517e4567d8ac387" alt="" | Message Router | How can you decouple individual processing steps so that messages can be passed to different filters depending on a set of conditions? |
data:image/s3,"s3://crabby-images/6cf89/6cf893f23000b363388a5eb0dbc100ac4d75317c" alt="" | Message Translator |
How can systems using different data formats communicate with each other using messaging?
|
data:image/s3,"s3://crabby-images/cd7f0/cd7f0f9d4a12ddca7c51ac342f6e7a5f55e75585" alt="" | Message Endpoint | How does an application connect to a messaging channel to send and receive messages? |
Messaging Channels |
data:image/s3,"s3://crabby-images/0f69f/0f69f42a581284405f822218f696e8d592c37317" alt="" | Introduction to Messaging Channels | |
data:image/s3,"s3://crabby-images/d9e95/d9e95626e9e6fe2a619e0dd1f578afcb9e098955" alt="" | Point-to-Point Channel | How can the caller be sure that exactly one receiver will receive the document or perform the call? |
data:image/s3,"s3://crabby-images/1670b/1670b022f55cae8433d61154e04b656f67bde3f7" alt="" | Publish-Subscribe Channel | How can the sender broadcast an event to all interested receivers? |
data:image/s3,"s3://crabby-images/f407e/f407e7d3b7015e3351e983224f918288e4a74ad6" alt="" | Datatype Channel | How can the application send a data item such that the receiver will know how to process it? |
data:image/s3,"s3://crabby-images/a0252/a0252b941f107e75830e142da7372b2d8ee975c0" alt="" | Invalid Message Channel | How can a messaging receiver gracefully handle receiving a message that makes no sense? |
data:image/s3,"s3://crabby-images/c0864/c086463527637d319234eabd7d8b0a902046f817" alt="" | Dead Letter Channel | What will the messaging system do with a message it cannot deliver? |
data:image/s3,"s3://crabby-images/15f2d/15f2dcba2676040a623258cf4e4547b146b708a5" alt="" | Guaranteed Delivery | How can the sender make sure that a message will be delivered, even if the messaging system fails? |
data:image/s3,"s3://crabby-images/48e9a/48e9ae6cfae0810144096459fc8b2652328020bf" alt="" | Channel Adapter | How can you connect an application to the messaging system so that it can send and receive messages? |
data:image/s3,"s3://crabby-images/a9d37/a9d3757f5a1f8f5fe672691eaea4302ccccc0df2" alt="" | Messaging Bridge | How can multiple messaging systems be connected so that messages available on one are also available on the others? |
data:image/s3,"s3://crabby-images/1a151/1a1510b720e6384d3105c169c4f09f0ef3eae108" alt="" | Message Bus | What is an architecture that enables separate applications to work together, but in a decoupled fashion such that applications can be easily added or removed without affecting the others? |
Message Construction |
data:image/s3,"s3://crabby-images/55d12/55d12b7d05d000b743b594053d39865850a870ed" alt="" | Introduction to Message Construction | |
data:image/s3,"s3://crabby-images/810c9/810c90b8f618c060e644a82b400741ff92e78a97" alt="" | Command Message | How can messaging be used to invoke a procedure in another application? |
data:image/s3,"s3://crabby-images/9d44b/9d44b6824125aabe70001398f4bfdf5e8810d689" alt="" | Document Message | How can messaging be used to transfer data between applications? |
data:image/s3,"s3://crabby-images/d5712/d571253bf0399d6f2aec4a26c556cf5dcf0ba15c" alt="" | Event Message | How can messaging be used to transmit events from one application to another? |
data:image/s3,"s3://crabby-images/6f4fe/6f4fe35c61ebabb337a03ce8025cdb2a4a329b1b" alt="" | Request-Reply | When an application sends a message, how can it get a response from the receiver? |
data:image/s3,"s3://crabby-images/79171/791714c411c122c5958c8fc4547607fe40deff73" alt="" | Return Address | How does a replier know where to send the reply? |
data:image/s3,"s3://crabby-images/fe723/fe723ddd44ae275f886449b120e13b7b531a8ae3" alt="" | Correlation Identifier | How does a requestor that has received a reply know which request this is the reply for? |
data:image/s3,"s3://crabby-images/5f33b/5f33be306eb7701fca3ac626569e4a66a3be2850" alt="" | Message Sequence | How can messaging transmit an arbitrarily large amount of data? |
data:image/s3,"s3://crabby-images/f2098/f2098a715fa469d6df98cce44ca58eae8b7ab3db" alt="" | Message Expiration | How can a sender indicate when a message should be considered stale and thus shouldn’t be processed? |
| Format Indicator | How can a message’s data format be designed to allow for possible future changes? |
Interlude: Simple Messaging |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Introduction to Simple Messaging Examples | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | JMS Request/Reply Example | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | .NET Request/Reply Example | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | JMS Publish/Subscribe Example | |
Message Routing |
| Introduction to Message Routing | |
data:image/s3,"s3://crabby-images/8e7c0/8e7c0acc67cbcd7298fc7a366517e4567d8ac387" alt="" | Content-Based Router |
How do we handle a situation where the implementation of a single logical function (e.g., inventory check) is spread across multiple physical systems?
|
data:image/s3,"s3://crabby-images/0759e/0759e3061d3d1c9e0177544e794b562b5b206496" alt="" | Message Filter | How can a component avoid receiving uninteresting messages? |
data:image/s3,"s3://crabby-images/daeab/daeab4a078586895302f40b9fbacba35fd408cc6" alt="" | Dynamic Router | How can you avoid the dependency of the router on all possible destinations while maintaining its efficiency? |
data:image/s3,"s3://crabby-images/093da/093da1652df516157bfd7b618795edc3d77c95ec" alt="" | Recipient List | How do we route a message to a list of dynamically specified recipients? |
data:image/s3,"s3://crabby-images/d35cc/d35cc4edacf1c75a2048f8c60cf3683c6d6aec9b" alt="" | Splitter |
How can we process a message if it contains multiple elements, each of which may have to be processed in a different way?
|
data:image/s3,"s3://crabby-images/6ceac/6ceac328bcd46065c8a6c4b1da5ca1e9ec0b0c1c" alt="" | Aggregator |
How do we combine the results of individual, but related messages so that they can be processed as a whole?
|
data:image/s3,"s3://crabby-images/66b8b/66b8b61246329b32e99f96ae15901fde480af0ef" alt="" | Resequencer | How can we get a stream of related but out-of-sequence messages back into the correct order? |
data:image/s3,"s3://crabby-images/e6415/e6415e44611a0a2396b4df28d9befa977a7657e5" alt="" | Composed Message Processor |
How can you maintain the overall message flow when processing a message consisting of multiple elements, each of which may require different processing?
|
data:image/s3,"s3://crabby-images/c941f/c941f5e427433a5eca4b038398eceb105402d52a" alt="" | Scatter-Gather |
How do you maintain the overall message flow when a message needs to be sent to multiple recipients, each of which may send a reply?
|
data:image/s3,"s3://crabby-images/8ea9f/8ea9f9da43feb8e24918ab9e351d1b73e126583d" alt="" | Routing Slip |
How do we route a message consecutively through a series of processing steps when the sequence of steps is not known at design-time and may vary for each message?
|
data:image/s3,"s3://crabby-images/5f7e8/5f7e8d9e3ca24c781439995bcb61eccdad42d06d" alt="" | Process Manager | How do we route a message through multiple processing steps when the required steps may not be known at design-time and may not be sequential? |
data:image/s3,"s3://crabby-images/39026/39026ecf981ee862479adbc8279ee90c39c39873" alt="" | Message Broker | How can you decouple the destination of a message from the sender and maintain central control over the flow of messages? |
Message Transformation |
data:image/s3,"s3://crabby-images/6cf89/6cf893f23000b363388a5eb0dbc100ac4d75317c" alt="" | Introduction to Message Transformation | |
data:image/s3,"s3://crabby-images/1daa0/1daa01c66e1647ecd7b8bf592143c3158a7db718" alt="" | Envelope Wrapper |
How can existing systems participate in a messaging exchange that places specific requirements on the message format, such as message header fields or encryption?
|
data:image/s3,"s3://crabby-images/9f2ed/9f2ed3e0448b39bead3e2bb2014fb90d90279f87" alt="" | Content Enricher |
How do we communicate with another system if the message originator does not have all the required data items available?
|
data:image/s3,"s3://crabby-images/2443b/2443bbc2952735e1302b9b3062e6bbe6f1a1154d" alt="" | Content Filter |
How do you simplify dealing with a large message, when you are interested only in a few data items?
|
data:image/s3,"s3://crabby-images/24bff/24bffa505e15fb9e5248a2ac78ac6b0436cd6b74" alt="" | Claim Check |
How can we reduce the data volume of message sent across the system without sacrificing information content?
|
data:image/s3,"s3://crabby-images/d0c5b/d0c5b19303815f1f1a20e3a75816b87bc808fcd6" alt="" | Normalizer | How do you process messages that are semantically equivalent, but arrive in a different format? |
| Canonical Data Model | How can you minimize dependencies when integrating applications that use different data formats? |
Interlude: Composed Messaging |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Introduction to Composed Messaging Examples | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Synchronous Implementation using Web Services | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Asynchronous Implementation with MSMQ | |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Asynchronous Implementation with TIBCO ActiveEnterprise | |
Messaging Endpoints |
data:image/s3,"s3://crabby-images/cd7f0/cd7f0f9d4a12ddca7c51ac342f6e7a5f55e75585" alt="" | Introduction to Messaging Endpoints | |
data:image/s3,"s3://crabby-images/19f4d/19f4de79464b5d86957e817da3c24df88e7f16bf" alt="" | Messaging Gateway | How do you encapsulate access to the messaging system from the rest of the application? |
data:image/s3,"s3://crabby-images/0cc07/0cc07e08d5fb029c148446cdbb5e71b5bfe3fd29" alt="" | Messaging Mapper | How do you move data between domain objects and the messaging infrastructure while keeping the two independent of each other? |
data:image/s3,"s3://crabby-images/90ea7/90ea71ce0bdb721e4dd93c6a1995f36897889c1c" alt="" | Transactional Client | How can a client control its transactions with the messaging system? |
data:image/s3,"s3://crabby-images/abce1/abce1695dea5a00541135303a266805fe0462e9b" alt="" | Polling Consumer | How can an application consume a message when the application is ready? |
data:image/s3,"s3://crabby-images/abe01/abe017d0b46958da29f6d191161b6932c784c1ef" alt="" | Event-Driven Consumer | How can an application automatically consume messages as they become available? |
data:image/s3,"s3://crabby-images/514ab/514abd8032f11929417db842008e430f7f36e10d" alt="" | Competing Consumers | How can a messaging client process multiple messages concurrently? |
data:image/s3,"s3://crabby-images/18fef/18fef975d7d3a7abec13f86765adfc80ac280eb2" alt="" | Message Dispatcher | How can multiple consumers on a single channel coordinate their message processing? |
data:image/s3,"s3://crabby-images/3db0c/3db0c888a4b3c53cb8bec426fc1c16234add0949" alt="" | Selective Consumer | How can a message consumer select which messages it wishes to receive? |
data:image/s3,"s3://crabby-images/c1d68/c1d685903cbc6da0f7dd56033603f9be0f147e6e" alt="" | Durable Subscriber | How can a subscriber avoid missing messages while it’s not listening for them? |
data:image/s3,"s3://crabby-images/d8522/d8522da6d48a358a9508c816cb341689408aaa65" alt="" | Idempotent Receiver | How can a message receiver deal with duplicate messages? |
data:image/s3,"s3://crabby-images/cc258/cc25882ea37e0cafe1eb4eaccc8ad5f96792bd11" alt="" | Service Activator | How can an application design a service to be invoked both via various messaging technologies and via non-messaging techniques? |
System Management |
| Introduction to System Management | |
data:image/s3,"s3://crabby-images/8fe0f/8fe0f66f2c17a85919e94c219aae7182f0fbf2ab" alt="" | Control Bus |
How can we effectively administer a messaging system that is distributed across multiple platforms and a wide geographic area?
|
data:image/s3,"s3://crabby-images/1141d/1141df2b09da650c795e3bc8c124a826fa9b0b2f" alt="" | Detour | How can you route a message through intermediate steps to perform validation, testing or debugging functions? |
data:image/s3,"s3://crabby-images/6f5af/6f5afced1da70d0c3f31dcdce2f55b90a3d60949" alt="" | Wire Tap | How do you inspect messages that travel on a point-to-point channel? |
| Message History |
How can we effectively analyze and debug the flow of messages in a loosely coupled system?
|
data:image/s3,"s3://crabby-images/06154/06154de21f08e40563eecd2ee7e5d9ae980ae3b4" alt="" | Message Store |
How can we report against message information without disturbing the loosely coupled and transient nature of a messaging system?
|
data:image/s3,"s3://crabby-images/438b0/438b008d4078be26cfe5b43e213f8a1d3e6d74b9" alt="" | Smart Proxy | How can you track messages on a service that publishes reply messages to the Return Address specified by the requestor? |
data:image/s3,"s3://crabby-images/d04ee/d04eed0e1e74ac415107df6e5ff1d57d2cce0bdc" alt="" | Test Message |
What happens, though, if a component is actively processing messages, but garbles outgoing messages due to an internal fault?
|
data:image/s3,"s3://crabby-images/f2ad9/f2ad93e8e6c11890865f1b66600bd55fe20499fd" alt="" | Channel Purger | How can you keep 'left-over' messages on a channel from disturbing tests or running systems? |
Interlude: Systems Management Example |
data:image/s3,"s3://crabby-images/fbb8e/fbb8ea0645b1a0f55ce000a60d58a3d3f2bdf203" alt="" | Loan Broker System Management | |
Integration Patterns in Practice |
| Case Study: Bond Trading System | |
Concluding Remarks |
| Emerging Standards and Futures in Enterprise Integration | |
Appendices |
| Bibliography |
Annotated list of references and recommended reading.
|
| Revision History |
Chronological list of changes.
|