| Messaging Patterns Overview | |
data:image/s3,"s3://crabby-images/33279/33279805ff81885b093b11d721f402b13e4cb4f1" alt="" | Table of Contents |
Detailed table of contents.
|
data:image/s3,"s3://crabby-images/e48ca/e48ca37440782888ff9064bc4e657e14c3b16f86" alt="" | Preface | |
data:image/s3,"s3://crabby-images/e48ca/e48ca37440782888ff9064bc4e657e14c3b16f86" alt="" | Introduction | |
data:image/s3,"s3://crabby-images/e48ca/e48ca37440782888ff9064bc4e657e14c3b16f86" alt="" | Solving Integration Problems using Patterns | |
Integration Styles |
data:image/s3,"s3://crabby-images/e48ca/e48ca37440782888ff9064bc4e657e14c3b16f86" alt="" | Introduction to Integration Styles | |
data:image/s3,"s3://crabby-images/7e2b6/7e2b6bfde7622fa7f3dc1d7067f413079bf9121c" alt="" | File Transfer | How can I integrate multiple applications so that they work together and can exchange information? |
data:image/s3,"s3://crabby-images/d1fe1/d1fe18aefea1473c3bd9a39384f478ff4c69ac0f" alt="" | Shared Database | How can I integrate multiple applications so that they work together and can exchange information? |
data:image/s3,"s3://crabby-images/c8ccf/c8ccf04e022b320c67081149df60ce02ee4c6ac4" 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/24e70/24e70b2ccf0d2c7f664ef333f7707e5ee5fe7d69" 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/24e70/24e70b2ccf0d2c7f664ef333f7707e5ee5fe7d69" alt="" | Introduction to Messaging Systems | |
data:image/s3,"s3://crabby-images/4062e/4062ea41da2644da07a14e2af21a69a1806e20ce" alt="" | Message Channel | How does one application communicate with another using messaging? |
data:image/s3,"s3://crabby-images/3d17f/3d17f40aec0c42a3c935a80a65a47333bdd5d4d8" alt="" | Message | How can two applications connected by a message channel exchange a piece of information? |
data:image/s3,"s3://crabby-images/35a32/35a32520c00f7bccc1ddc52264991c25e8955d0e" alt="" | Pipes and Filters |
How can we perform complex processing on a message while maintaining independence and flexibility?
|
data:image/s3,"s3://crabby-images/0b698/0b698c881be348ecfa9fe97e59f683d97405ed5f" 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/94e75/94e756eadc72302961264e473f4a37b9edb81e9e" alt="" | Message Translator |
How can systems using different data formats communicate with each other using messaging?
|
data:image/s3,"s3://crabby-images/86066/86066a884497a576de66f2898631e699cf053b59" 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/4062e/4062ea41da2644da07a14e2af21a69a1806e20ce" alt="" | Introduction to Messaging Channels | |
data:image/s3,"s3://crabby-images/2ce52/2ce52eb800f511051102562a84936b4f2717bb4c" 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/b1e26/b1e2607a26fbad828b9e982fb883aa4c101317a2" alt="" | Publish-Subscribe Channel | How can the sender broadcast an event to all interested receivers? |
data:image/s3,"s3://crabby-images/f927f/f927f27c22659c2785d470d5238c5f75656af82f" 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/4b12b/4b12bfb7f48d42b4580e6db41299283e74257a39" alt="" | Invalid Message Channel | How can a messaging receiver gracefully handle receiving a message that makes no sense? |
data:image/s3,"s3://crabby-images/ced38/ced3834a1da23e0569141d72fe995976eb40b318" alt="" | Dead Letter Channel | What will the messaging system do with a message it cannot deliver? |
data:image/s3,"s3://crabby-images/22621/226215998e245a6ec97d41c664c5032a6c54fcdb" 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/8a56d/8a56d1dd6332697510c4a5c48e66ca293cb66ce7" 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/b259d/b259d170f1f51c03a8c1eece92e7cc61774ea7c7" 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/7e3fc/7e3fc406deb0e77ec0217af7321e6f064bd0cfc6" 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/3d17f/3d17f40aec0c42a3c935a80a65a47333bdd5d4d8" alt="" | Introduction to Message Construction | |
data:image/s3,"s3://crabby-images/2e402/2e4020f981ad1fe4478c57a4870531d28c79b803" alt="" | Command Message | How can messaging be used to invoke a procedure in another application? |
data:image/s3,"s3://crabby-images/c9d77/c9d779a064370c9a254374a9f56c7f83e1836823" alt="" | Document Message | How can messaging be used to transfer data between applications? |
data:image/s3,"s3://crabby-images/930fc/930fc1b3ea43f6a80a496874fefa33dda2c91b4f" alt="" | Event Message | How can messaging be used to transmit events from one application to another? |
data:image/s3,"s3://crabby-images/c1a6a/c1a6aebc94857283a39ee8281d94d7ff5a96d3f9" alt="" | Request-Reply | When an application sends a message, how can it get a response from the receiver? |
data:image/s3,"s3://crabby-images/7e62b/7e62bf14fb39387464833debb25440f0a4b2041f" alt="" | Return Address | How does a replier know where to send the reply? |
data:image/s3,"s3://crabby-images/b85b5/b85b54e140902b2edb90d038c8a486c529df8647" 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/a2348/a23489f48dbe71d9c7aa4eb24f85afcc88d1d273" alt="" | Message Sequence | How can messaging transmit an arbitrarily large amount of data? |
data:image/s3,"s3://crabby-images/271a9/271a908beb8ae86a9d59969d1c0ff167a6d348a6" 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/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | Introduction to Simple Messaging Examples | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | JMS Request/Reply Example | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | .NET Request/Reply Example | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | JMS Publish/Subscribe Example | |
Message Routing |
| Introduction to Message Routing | |
data:image/s3,"s3://crabby-images/0b698/0b698c881be348ecfa9fe97e59f683d97405ed5f" 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/2a1e9/2a1e92a687b66b0182fbf5ee477e914ad8fa8300" alt="" | Message Filter | How can a component avoid receiving uninteresting messages? |
data:image/s3,"s3://crabby-images/744c0/744c02c4e3a93f2fe8dc388060e314dd071758a4" 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/35504/3550424014423c891a7a8a566488e9c45d793fd8" alt="" | Recipient List | How do we route a message to a list of dynamically specified recipients? |
data:image/s3,"s3://crabby-images/c5fff/c5fffc3f291bca93a6e3986d8e5c6eae1649a2c9" 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/79e7b/79e7bd24bcac127b2445f25cf18f437d6a4df6fb" 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/38750/38750406684a6adccd6f0c830a8fe2d7a800279b" 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/07d25/07d2523312920c03bac3958591247222a15dc3d1" 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/cb243/cb243b14acb670386fc34c6e3e158fb5b15592e9" 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/d0e6d/d0e6d6dba208cc9ec4246622797ef9756f10c078" 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/fbccf/fbccf4c467e3745b6df035caba17f7ea4a4888ce" 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/ca159/ca159ff08acdc45ff2bf56221e5e81521403d8f5" 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/94e75/94e756eadc72302961264e473f4a37b9edb81e9e" alt="" | Introduction to Message Transformation | |
data:image/s3,"s3://crabby-images/4ddfd/4ddfdddc6ebbca694704c30445e14dc5c3086509" 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/f64cb/f64cb6e517284065365146eb8d3e3a0387b26751" 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/7f8f0/7f8f0c101388de8ba75cc13c28b7849a512484e9" 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/1ac63/1ac636016706c80cab4d519e775fc73d81fdbb6b" 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/fe18f/fe18fe07fcde2af213de0c046a897dec55d01b02" 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/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | Introduction to Composed Messaging Examples | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | Synchronous Implementation using Web Services | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | Asynchronous Implementation with MSMQ | |
data:image/s3,"s3://crabby-images/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" alt="" | Asynchronous Implementation with TIBCO ActiveEnterprise | |
Messaging Endpoints |
data:image/s3,"s3://crabby-images/86066/86066a884497a576de66f2898631e699cf053b59" alt="" | Introduction to Messaging Endpoints | |
data:image/s3,"s3://crabby-images/e20d9/e20d98aca0b44250aced95466c13164a2af48fff" alt="" | Messaging Gateway | How do you encapsulate access to the messaging system from the rest of the application? |
data:image/s3,"s3://crabby-images/a8806/a8806c9f889bd4707dfe84bd974cc9aaa3da3d02" 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/f9833/f983376093725259d267c72ebf8a08265495b353" alt="" | Transactional Client | How can a client control its transactions with the messaging system? |
data:image/s3,"s3://crabby-images/a953b/a953b3d45f6ac31744dbb02e552fe5491da5027f" alt="" | Polling Consumer | How can an application consume a message when the application is ready? |
data:image/s3,"s3://crabby-images/1fdcd/1fdcd10479d4653b69f7e21c550c2e44343d40ad" alt="" | Event-Driven Consumer | How can an application automatically consume messages as they become available? |
data:image/s3,"s3://crabby-images/b04de/b04de8e070fb47115fc3a4c6567a7cd017aaea52" alt="" | Competing Consumers | How can a messaging client process multiple messages concurrently? |
data:image/s3,"s3://crabby-images/fea53/fea530dd3d9644f8748da9639eade970920d0b09" alt="" | Message Dispatcher | How can multiple consumers on a single channel coordinate their message processing? |
data:image/s3,"s3://crabby-images/0ec90/0ec903474efdbaa182de2d403e22e90e1206029d" alt="" | Selective Consumer | How can a message consumer select which messages it wishes to receive? |
data:image/s3,"s3://crabby-images/df524/df524c69d518232c1ad2343ea2a1963089328d07" alt="" | Durable Subscriber | How can a subscriber avoid missing messages while it’s not listening for them? |
data:image/s3,"s3://crabby-images/ae5fe/ae5fedf600a443a7f4c2575e147abeaf9ea1bfd0" alt="" | Idempotent Receiver | How can a message receiver deal with duplicate messages? |
data:image/s3,"s3://crabby-images/799d8/799d826f16de39c9bc595aae11c9519a7292c02a" 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/61e5a/61e5a0567b7dbbb86fb944394dd37ccaed112738" 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/73a25/73a25d6525140e6088d8c8560d0584c55fc40ada" alt="" | Detour | How can you route a message through intermediate steps to perform validation, testing or debugging functions? |
data:image/s3,"s3://crabby-images/f50f2/f50f20119bf8eaa94ff685187e8e75e29c9ce22b" 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/5b9d2/5b9d28d933d8e8d2f5ec2d0cb54757e4cf5ca2d4" 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/a1bb1/a1bb1292bdee20d25dbc860aae594bed143331fa" 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/d5554/d5554aaf070a5c2c8037d94d951b84c2b5e75b94" 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/7d42e/7d42e7cbbff3532678a43324be84f6937c9abe4e" 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/ccf99/ccf9924b2c2f7f0a4f2a48f72909ad932ade6e8b" 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.
|