CIS007-3 Comparative Integrated Systems

Slides:



Advertisements
Similar presentations
MQ Series Cross Platform Dominant Messaging sw – 70% of market Messaging API same on all platforms Guaranteed one-time delivery Two-Phase Commit Wide EAI.
Advertisements

DISTRIBUTED COMPUTING PARADIGMS
Chapter 4: Communication*
Message Queues COMP3017 Advanced Databases Dr Nicholas Gibbins –
Tanenbaum & Van Steen, Distributed Systems: Principles and Paradigms, 2e, (c) 2007 Prentice-Hall, Inc. All rights reserved DISTRIBUTED SYSTEMS.
Distributed components
CS 582 / CMPE 481 Distributed Systems Communications (cont.)
Click to add text Introduction to z/OS Basics © 2006 IBM Corporation Chapter 15: WebSphere MQ.
Chapter 2 Network Models.
Message-Oriented Communication Synchronous versus asynchronous communications Message-Queuing System Message Brokers Example: IBM MQSeries 02 – 26 Communication/2.4.
Tanenbaum & Van Steen, Distributed Systems: Principles and Paradigms, 2e, (c) 2007 Prentice-Hall, Inc. All rights reserved DISTRIBUTED SYSTEMS.
Messaging Technologies Group: Yuzhou Xia Yi Tan Jianxiao Zhai.
Protocols and the TCP/IP Suite Chapter 4. Multilayer communication. A series of layers, each built upon the one below it. The purpose of each layer is.
Process-to-Process Delivery:
Tanenbaum & Van Steen, Distributed Systems: Principles and Paradigms, 2e, (c) 2007 Prentice-Hall, Inc. All rights reserved DISTRIBUTED SYSTEMS.
What is a Protocol A set of definitions and rules defining the method by which data is transferred between two or more entities or systems. The key elements.
Client Server Technologies Middleware Technologies Ganesh Panchanathan Alex Verstak.
SEED Infotech Pvt. Ltd. 1 Networking in Java. SEED Infotech Pvt. Ltd. 2 Objectives of This Session Describe issues related to any type of network using.
Protocols and the TCP/IP Suite
Networks – Network Architecture Network architecture is specification of design principles (including data formats and procedures) for creating a network.
Mukesh N. Tekwani Elphinstone College Mumbai
Jozef Goetz, Application Layer PART VI Jozef Goetz, Position of application layer The application layer enables the user, whether human.
The OSI Model An ISO (International standard Organization) that covers all aspects of network communications is the Open System Interconnection (OSI) model.
1 Introduction to Middleware. 2 Outline What is middleware? Purpose and origin Why use it? What Middleware does? Technical details Middleware services.
OCT 1 Master of Information System Management Organizational Communications and Distributed Object Technologies Lecture 5: JMS.
Tanenbaum & Van Steen, Distributed Systems: Principles and Paradigms, 2e, (c) 2007 Prentice-Hall, Inc. All rights reserved DISTRIBUTED SYSTEMS.
9 September 2008CIS 340 # 1 Topics reviewTo review the communication needs to support the architectures variety of approachesTo examine the variety of.
Chapter 15 – Part 2 Networks The Internal Operating System The Architecture of Computer Hardware and Systems Software: An Information Technology Approach.
Message Oriented Communication Prepared by Himaja Achutha Instructor: Dr. Yanqing Zhang Georgia State University.
Tanenbaum & Van Steen, Distributed Systems: Principles and Paradigms, 2e, (c) 2007 Prentice-Hall, Inc. All rights reserved RPC Tanenbaum.
Hwajung Lee.  Interprocess Communication (IPC) is at the heart of distributed computing.  Processes and Threads  Process is the execution of a program.
Distributed (Operating) Systems -Communication in Distributed Systems- Computer Engineering Department Distributed Systems Course Assoc. Prof. Dr. Ahmet.
AMQP, Message Broker Babu Ram Dawadi. overview Why MOM architecture? Messaging broker like RabbitMQ in brief RabbitMQ AMQP – What is it ?
1 Kyung Hee University Chapter 11 User Datagram Protocol.
TCP/IP1 Address Resolution Protocol Internet uses IP address to recognize a computer. But IP address needs to be translated to physical address (NIC).
1 CIS007-3 Comparative Integrated Systems Communication including Message Oriented Middleware (Remote Procedure Call, Message and Stream-Oriented Communication)
MQ Series Cross Platform Dominant Messaging sw – 70% of market
Chapter 11 User Datagram Protocol
The Transport Layer Implementation Services Functions Protocols
Chapter 9: Transport Layer
Last Class: Introduction
Instructor Materials Chapter 9: Transport Layer
Prof. Leonardo Mostarda University of Camerino
Layered Architectures
Last Class: RPCs and RMI
Chapter 9 – RPCs, Messaging & EAI
CHAPTER 3 Architectures for Distributed Systems
#01 Client/Server Computing
Protocols and the TCP/IP Suite
Chapter 14 User Datagram Protocol (UDP)
Process-to-Process Delivery:
Harjutus 3: Aünkroonne hajussüsteemi päring
Inventory of Distributed Computing Concepts
Software models - Software Architecture Design Patterns
PRESENTATION COMPUTER NETWORKS
Chapter 15 – Part 2 Networks The Internal Operating System
Networking Theory (part 2)
Net 323 D: Networks Protocols
Message Queuing.
MQ Series Cross Platform Dominant Messaging sw – 70% of market
Enterprise Integration
WEB SERVICES From Chapter 19, Distributed Systems
J2EE Lecture 13: JMS and WebSocket
Protocols and the TCP/IP Suite
OSI Reference Model Unit II
Process-to-Process Delivery: UDP, TCP
OSI Model 7 Layers 7. Application Layer 6. Presentation Layer
Communication.
#01 Client/Server Computing
Networking Theory (part 2)
Presentation transcript:

CIS007-3 Comparative Integrated Systems Communication including Message Oriented Middleware (Remote Procedure Call, Message and Stream-Oriented Communication) Sue Brandreth

Outline Introduction Fundamentals: Layered Protocols, Middleware, Types of Communication (Remote Procedure Call (RPC)) Message-Oriented Communication Transient communication Persistent communication (Stream-Oriented Communication)

Introduction

Review In a distributed system, processes run on different machines exchange information through message passing Successful distributed systems depend on communication models that hide or simplify message passing

Interprocess Communication Modern distributed systems consist of thousands or even millions of processes scattered across a network such as the Internet To study distributed systems we need to examine how processes on different machines exchange information Challenge: the underlying network is unreliable! Interprocess communication is at the heart of all distributed systems

Interprocess Communication How can processes on different remote machines exchange information? No primitives based on shared memory (like in non-distributed parallel systems) Communication in distributed systems Based on low-level message passing Offered by the underlying network Harder than using shared memory

Three Models for Communication Three widely used models for communication: Remote Procedure Call (RPC) Hide most of the intricacies of message passing Ideal for client/server applications Message-Oriented Middleware (MOM) High-level message queuing model, similar to email Communication does not follow the rather strict pattern of client/server interaction.

Three Models for Communication Data Streaming (Stream Oriented Communication) Used in multimedia distributed systems Provides support for communication of continuous media, such as audio and video Stream: continuous flow of messages Subject to various timing constraints

Layered Protocols; Middleware; Types of Communication Fundamentals

Layered Protocols: OSI Model Physical: transferring bits Data link: Detect and correct errors, checksum, parity bit, CRC etc, group bits into frames Network: Routing, IP protocol (connectionless), IP packet Transport: Reliable connection, handle package losses, TCP (Connection-oriented) and UDP (connectionless) Session: Synchronisation, dialog control Presentation: Semantics Application: All application protocols (FTP, HTTP -> these are special purpose protocols, but HTTP became a more general purpose one) TCP/IP: All above Transport is Application Layers, interfaces, and protocols in the OSI model.

Layered Protocols: Headers A typical message as it appears on the network.

What is Middleware? An application that logically lives (mostly) in the application layer Contains many middleware protocols General purpose Application independent “Glue” between actual applications and lower-level layers Middleware is an application that logically lives (mostly) in the application layer, but contains many general-purpose protocols that warrant their own layers, independent of other, more specific applications. Middleware protocols are used for establishing various middleware services, e.g., authentication protocols that are not closely tied to any specific application, but can be integrated into a middleware system as a general service. Authorisation protocols tend to have a general, application-independent nature. The distributed locking protocol by which a shared resource can be protected against simultaneous access by a collection of processes being distributed across multiple machines.

What is Middleware? Provides a communication infrastructure for application On top of a distributed system Provides an API Data transformation Error handling Localization and identification of client and server Middleware is an application that logically lives (mostly) in the application layer, but contains many general-purpose protocols that warrant their own layers, independent of other, more specific applications. Middleware protocols are used for establishing various middleware services, e.g., authentication protocols that are not closely tied to any specific application, but can be integrated into a middleware system as a general service. Authorisation protocols tend to have a general, application-independent nature. The distributed locking protocol by which a shared resource can be protected against simultaneous access by a collection of processes being distributed across multiple machines.

Types of Middleware Remote Procedure Call (RPC) Historic interest Object-Oriented Middleware (OOM) Java RMI CORBA Message-Oriented Middleware (MOM) Java Message Service IBM MQSeries Web Services Event-Based Middleware Transaction Processing Monitors (TPM) Object Request Brokers (ORB)

Message Oriented Middleware Message Oriented Middleware (or “MOM”) is one particular form of middleware, which is capable of facilitating the transportation of asynchronous messages from one component to another.

Middleware Protocols Used for establishing various middleware services Example Middleware protocols: Authentication and authorisation protocols Not closely tied to any specific application, but a general service Distributed commit protocol All processes carry out an operation or the operation is not carried out at all Distributed locking protocol Shared resource can be protected against simultaneous access by a collection of processes being distributed across multiple machines Middleware is an application that logically lives (mostly) in the application layer, but contains many general-purpose protocols that warrant their own layers, independent of other, more specific applications. Middleware protocols are used for establishing various middleware services, e.g., authentication protocols that are not closely tied to any specific application, but can be integrated into a middleware system as a general service. Authorisation protocols tend to have a general, application-independent nature. The distributed locking protocol by which a shared resource can be protected against simultaneous access by a collection of processes being distributed across multiple machines.

Middleware Communication Protocols Support high-level communication services, ie. Call a procedure or invoke an object on a remote machine (in a highly transparent way) Message-passing services (comparable to those offered by the transport layer). Reliable multicast-services Scale to thousands of receivers across a wide-area network Must be implemented with application requirements in mind (hence in Middleware rather than in transport layer) Middleware communication protocols support high-level communication services, e.g., Protocols that allow a process to call a procedure or invoke an object on a remote machine in a highly transparent way. Protocols that offer message-passing services (comparable to those offered by the transport layer). Protocols that help offer reliable multicast services that scale to thousands of receivers across a wide-area network. The reason not to put them into transport layer and instead to keep them in a higher (middleware) layer is due to the fact that reliable multicasting services that guarantee scalability can be implemented only if application requirements are taken into account. The original transport services may also be offered as a middleware service, without being modified.

Adapted Communication Reference Model Slightly adapted reference model. Session and Presentation have been replaced An adapted reference model for networked communication.

COMMUNICATION MODELS

Classification based on type of content: Events Commands Data Streams

QUIZ TIME

QUIZ TIME

QUIZ TIME

QUIZ TIME

QUIZ TIME

QUIZ TIME

QUIZ TIME

QUIZ TIME

Types of Communications Middleware offers the various alternatives in communication to applications Types of communication can be classified along several dimensions: Persistent vs. transient Synchronous vs. asynchronous Discrete vs. streaming Various combinations are possible

Persistent vs. Transient Communication Persistent communication Message stored by the communication middleware as long as it takes to deliver it Sender can terminate after executing send. Sending application does not need to continue execution after submitting the message (allows for asynchronous communication) Receiving application need not be executing when the message is submitted. Receiver will get message next time it runs. Example: email systems The middleware offers the various alternatives in communication to applications (persistent vs transient; asynchronous vs synchronous): Persistent communication A message that has been submitted for transmission is stored by the communication middleware (at one or several of its storage facilities) as long as it takes to deliver it to the receiver. Consequently, the sending application does not need to continue execution after submitting the message. Likewise, the receiving application need not be executing when the message is submitted. Example: email systems Transient communication A message is stored by the communication system only as long as the sending and receiving applications are executing. Consequently, if the middleware cannot deliver a message due to a transmission interrupt, or because the recipient is currently not active, the message will simply be discarded. Example: transport-level communication services (being built upon traditional store-and-forward routers – if the router can’t deliver, it drops the message)

Persistent vs. Transient Communication Message is stored by the communication system only as long as the sending and receiving applications are executing. Communication errors or inactive receiver cause the message to be discarded Transport-level communication is transient If the middleware cannot deliver a message due to a transmission interrupt, or because the recipient is currently not active, the message will simply be discarded Example: transport-level communication services (being built upon traditional store-and-forward routers – if the router can’t deliver, it drops the message) The middleware offers the various alternatives in communication to applications (persistent vs transient; asynchronous vs synchronous): Persistent communication A message that has been submitted for transmission is stored by the communication middleware (at one or several of its storage facilities) as long as it takes to deliver it to the receiver. Consequently, the sending application does not need to continue execution after submitting the message. Likewise, the receiving application need not be executing when the message is submitted. Example: email systems Transient communication A message is stored by the communication system only as long as the sending and receiving applications are executing. Consequently, if the middleware cannot deliver a message due to a transmission interrupt, or because the recipient is currently not active, the message will simply be discarded. Example: transport-level communication services (being built upon traditional store-and-forward routers – if the router can’t deliver, it drops the message)

Persistent vs. Transient Communication Persistent communication: A message is stored at a communication server as long as it takes to deliver it to the receiver. Transient communication: A message is discarded by a communication server as soon as it cannot be delivered at the next server, or at the receiver.

Asynchronous vs. Synchronous Communication Asynchronous communication Sender continues execution immediately after it has submitted its message to the middleware software Message is (temporarily) stored immediately by the middleware upon submission Non-blocking Synchronous communication Sender is blocked until its request is known to be accepted ie. The OS or middleware notifies acceptance of the message, or The message has been delivered to the receiver, or The receiver processes it and returns a response Asynchronous communication A sender continues immediately after it has submitted its message for transmission. That is, the message is (temporarily) stored immediately by the middleware upon submission. Synchronous communication The sender is blocked until its request is known to be accepted Essentially, three points where synchronisation can take place. The sender may be blocked until the middleware notices that it will take over transmission of the request. its request has been delivered to the intended recipient its request has been fully processed, up to the time that the recipient returns a response.

Synchronous Communication Some observations: Client/Server computing is generally based on a model of synchronous communication: Client and server have to be active at the time of communication Client issues request and blocks until it receives reply Server essentially waits only for incoming requests, and subsequently processes them Drawbacks of synchronous communication: Client cannot do any other work while waiting for reply Failures have to be dealt with immediately (the client is waiting) In many cases the model is simply not appropriate (mail, news)

Synchronous Communication: Three Synchronization Points Three possible points of synchronisation: The sender may be blocked until the middleware notices that it will take over transmission of the request; its request has been delivered to the intended recipient; its request has been fully processed, up to the time that the recipient returns a response

Asynchronous Communication: Messaging Message-oriented middleware: Aims at high-level asynchronous communication: Processes send each other messages, which are queued Sender need not wait for immediate reply, but can do other things Middleware often ensures fault tolerance

Discrete vs. Streaming Communication All communicating parties communicate by messages Each message forms a complete unit of information Streaming Messages are related to each other By the order they are sent By their temporal relationship One-way communication; a “session” consists of multiple messages from the sender that are related either by send order (TCP streams), temporal proximity (multimedia streams), etc. Discrete: all communicating parties communicate by messages, each message forming a complete unit of information. Streaming: involves sending multiple messages, one after another, which are related to each other by the order they are sent and by their temporal relationship.

Combinations Various combinations of persistent/transient with asynchronous/synchronous communications exist in practice, ie. Persistence combined with synchronisation at request submission a common scheme for many message-queuing systems Transient communication with synchronisation after the request has been fully processed a scheme for Remote Procedure Calls

Messaging Combinations

Important….. RPC supports access transparency, but is not always appropriate RPC is usually synchronous, and is transient Message-oriented communication is more flexible

Message-oriented Communication

Message-Oriented Middleware (MOM) Communication using messages Messages stored in message queues Message servers decouple client and server Various assumptions made about message content Client App. Server App. Message Servers local message queues message queues local message queues Network Network Network

Forms of MOM Forms of MOM: Message Queuing Publish-Subscribe

Message-Oriented Persistent Communication Message Queuing Systems or Message-Oriented Middleware (MOM) Important class of message-oriented middleware services Persistent asynchronous communication Offer intermediate-term storage capacity for messages No need for either the sender or receiver to be active during message transmission Support message transfers that are allowed to take minutes.

Properties of MOM Asynchronous interaction Client and server are only loosely coupled Messages are queued Good for application integration Support for reliable delivery service Keep queues in persistent storage Processing of messages by intermediate message server(s) May do filtering, transforming, logging, … Networks of message servers Natural for database integration

Message-Queuing Model Basic idea: applications communicate by inserting messages in specific queues Messages forwarded over a series of communication servers before being finally being delivered to the destination Receiver can be down when message was sent No need for the sender to be executing when a message is picked up by the receiver Sender is offered the guarantee that its message will eventually be inserted into the recipient’s queue, but no guarantee about when Basic idea: applications communicate by inserting messages in specific queues These messages could be forwarded over a series of communication servers before being finally delivered to the destination, even if the destination was down when the message was sent The sender is offered the guarantee that its message will eventually be inserted into the recipient’s queue, but no guarantee about when. No need for the receiver to be executing when a message is being sent to its queue. Likewise, no need for the sender to be executing when a message is picked up by the receiver

Message-Oriented Middleware Persistent. Processes communicate through message queues Queues are maintained by the message-queuing system Sender appends to queue, receiver removes from queue Neither the sender nor receiver needs to be on-line when the message is transmitted

Synchronous Communication

Synchronous Communication Also known as ‘Rendevouz’ Tightly coupled Pros: Client is informed about message delivery No buffering necessary Cons: Sender and receiver have to run on the same time Direct connection necessary Client is blocked Lower degree of parallelity

Asynchronous (Persistent) Communication

Asynchronous (Persistent) Communication Loosely coupled Pros: Higher degree of parallelity Enables faster sending than transmitting May compensate speed deviation between sender and receiver (but not speed differences) Sender and receiver have not to run on the same time Cons: Complicates synchronisation Sender has no information about message delivery Possible buffer overflows

Asynchronous (Persistent) Communication Asynchronous data transport between processes Data is transmitted in messages Based on queues Sender puts messages into a queues Message is transmitted to receiver Receiver reads message from queues Usually FIFO

Queues Are named message destination that serve as an intermediate between sender and receiver Allow processes to execute and fail independently Can mask process failures and communication failures

Message Priorities – Highest Priority First

Message Priorities – Weighted Fair Scheduling

Message Oriented Middleware Additional / Optionally Support of multiple Messaging models Queue management Connection Management Quality-of-Service (QoS) Data transformation

Queue Manager Is a specialized kind of database Provides queuing functionality via an API to applications Provides means for administration Creation/deletion of queues Allows to start and to stop queues Alter properties of existing queues Allows monitoring of performance, failures, and recoveries Often queue managers can be configured to forward messages to other queue managers

Additional / Optional Queue Manager Functionality Often called Message Broker Message Transformation Primary function = Reformatting data/information “Rosetta stone” of the system -> universal translation Understands the structure/formats of sources and targets Intelligent Routing Flow control See ‘Content based routing’ Message Dictionary Rules Engine Repository Filtering Access control

MOM – Message Oriented Middleware

Time Decoupling by Queues

Location Decoupling by Queues

Types of Message Based Communication

Asynchronous Persistent Most important Quality of Service is guaranteed delivery Possible failures: Receiver is not running. No connection to receiver. Guaranteed delivery by persistent storage on intermediate nodes ie. as a file or in database If the receiver is up again or if the connection is available, message is delivered. Guaranteed delivery but not always in time.

Queuing Messaging Pattern One-to-One One sender, one receiver Point-to-Point Message Passing (MP) One-to-Many One sender, many receivers Many-to-One Many senders, one receiver Many-to-Many Many senders, many receivers -> Publish and Subscribe

Message Passing / Point-to-Point

Publish and Subscribe

Publish/Subscribe Model One important and common use of a Message Broker is to help form the Publish/Subscribe model (paradigm) In such a model, a broker is responsible not only for converting messages but also for matching applications based on the messages that are being exchanged Applications may publish a message on topic X by sending it to the broker Applications with interest in messages on topic X can subscribe to these messages, and will then receive them from the broker

Publish and Subscribe Example

Request/Reply with Queues Correlation ID used to match request with corresponding reply at the client

Message Based Systems / MOM Products Canonical example: IBM MQSeries (Sockets) – Berkeley Sockets OpenJMS Apache ActiveMQ (maintained by Fusesource) IBM WebSphere MQ (IBMs MQSeries) TIBCO TIBCO Rendezvous Oracle Advanced Queuing Microsoft Microsoft Message Queuing (MSMQ) SUN Sun ONE Message Queue (JMS) RabbitMQ JBoss HornetQ

What is IBM WebSphere? WebSphere provides software for SOA environments that enables dynamic, interconnected business processes, and delivers highly effective application infrastructures for all business situations. WebSphere is IBM's application and integration software platform, and includes the entire middleware infrastructure, including servers, services, and tools, needed to create, deploy, run, and monitor round-the-clock, enterprise-wide web applications and cross-platform, cross-product solutions. https://www.ibm.com/developerworks/websphere/newto/

WebSphere MQ (IBM) Cross Platform Dominant Messaging software – 70% of market Messaging API same on all platforms Guaranteed one-time delivery Two-Phase Commit Wide EAI industry support

MQ Series API (Basic) Connect to a Queue Manager Open a queue Put or get messages Close a queue Commit or roll back Disconnect

MQ Series API (Advanced Features) Triggering – automatically starting an application to process a message IMS and CICS Bridges – reusing legacy transactions without modification Confirmation of message arrival, delivery Grouping of messages Load balancing

Local Queuing

Distributed Queuing

MQSeries

Distributed Queuing

MS Message Queue (MQ) Deployed in its Windows Server operating systems since Windows NT 4 and Windows 95 .NET: System.Messaging Create Queues via computer administration Queue name: „Computername\private$\Queuename“

What is MSMQ? Message Queuing (MSMQ) technology enables applications running at different times to communicate across heterogeneous networks and systems that may be temporarily offline. Applications send messages to queues and read messages from queues. The following illustration shows how a queue can hold messages that are generated by multiple sending applications and read by multiple receiving applications. https://msdn.microsoft.com/en-us/library/ms711472%28v=vs.85%29.aspx

MSMQ Features Point-to-point messaging Persistent Transactional Trigger Normal send/receive APIs Very similar to IBM MQ Series Supports IP multicast as well…

MSMQ Queue Types Application Queues Destination Queues Private Public ComputerName\private$\QueueName\ private$\QueueName Public Response Queues Temporary / Local Queues

MSMQ Queue Types Application Queues Destination Queues Response Queues Private ComputerName\private$\QueueName\ private$\QueueName Public Response Queues Temporary / Local Queues System Queues Mediation Queues Dead Letter Queues Journal Queues

Amazon SQS Part of the AWS Cloud Computing Infrastructure Amazon Elastic Compute Cloud (Amazon EC2) Amazon Simple Storage Service (Amazon S3) Amazon Elastic BlockStore Amazon CloudFront Amazon SimpleDB … Amazon Simple Queue Service (Amazon SQS™)

Amazon SQS

Amazon SQS Features Multiple consumers and producers Configurable Message Queues Unlimited number of queues and messages SOAP – APIs Language support Java, PHP, Ruby, .NET At-Least-Once delivery No guarantee of message order

Amazon SQS Operations CreateQueue ListQueues DeleteQueue SendMessage ReceiveMessage DeleteMessage SetQueueAttributes GetQueueAttributes

Amazon SQS Queues and Message Identifier – Queue URL http://queue.amazonaws.com/123456790815/queue42 – Message ID – Receipt Handler MbZj6wDWli+JvwwJaBV+3dcjk2YW2vA3+STFFljTM8tJJg6HRG6PYSasuWXPJB+Cw Lj1FjgXUv1uSj1gUPAWV66FU/WeR4mq2OKpEGYWbnLmpRCJVAyeMjeU5ZBdtcQ+QE auMZc8ZRv37sIW2iJKq3M9MFx1YvV11A2x/KSbkJ0=

Amazon SQS

Amazon SQS

Java Message Service (JMS) Interface specification by Sun Microsystems to define access to MOM Defines syntax and semantics First published in 1988 Current specification: ??? JMS supports: Point-to-Point Publish-and-Subscribe Request/Reply

Java Message Service (JMS) Two roles: JMS Provider = MOM Server = Queue Manger = Message Broker JMS Client = Sender = Receiver Messages Administrative Objects published by the JMS provider using JINI ConnectionFactory DestinationFactory

JMS Features Transacted sessions Persistent/nonpersistent delivery Durable / non durable subscriber TTL Message Priorities Message selectors SQL-like syntax to access header fields: subscriber = session.createSubscriber(topic, “priority > 6 AND type = ‘alert’ ”); JMS can be used as a transport layer for SOAP Message Consumption Synchronously Asynchronously

JMS Example

JMS Example - HelloWorld // Use JNDI to get ConnectionFactory and Queue QueueConnectionFactory connectionFactory = QueueConnectionFactory) ctx.lookup ("QueueConnectionFactory"); // Create connection and session QueueConnection queueConnection connectionFactory.createQueueConnection(); QueueSession queueSession queueConnection.createQueueSession(...); Queue queue = (Queue) ctx.lookup ("myQueue"); QueueSender sender = queueSession.createSender(queue); // Create and send a message Message message = queueSession.createTextMessage(); message.setText("Hello World"); queueSender.send(message);

Apache ActiveMQ Leading Open Source messaging platform Multi-Language Support Clients and Protocols from C, C++, C#, Ruby, Perl, Python, PHP Supported Java Standards: JMS 1.1, J2EE 1.4, JCA 1.5 Multi-Protocol Support: TCP, NIO, UDP, SSL, HTTP/S, STOMP

Apache ActiveMQ Features Failover High Availability Clustering Wide area deployment Management Security

Apache ActiveMQ: Failover failover:(tcp://broker1:61616,tcp://broker2:6 1616,tcp://broker3:61616)?initialReconnectDelay=100 failover://(tcp://masterhost:61616,tcp://slavehost:61616)?randomize=false

Apache ActiveMQ: Synchronous Consumer public class MyConsumer { ... public void doCreateConsumer() { Destination destination = consumer.getSession().createQueue("JOBS." + job); MessageConsumer messageConsumer = consumer.getSession().createConsumer(destination); while ((message = consumer.receive(timeout)) != null) { processMessage(message); }

Apache ActiveMQ: Asynchronous Consumer public class MyConsumer { ... public void doCreateConsumer() { Destination destination = consumer.getSession().createQueue("JOBS." + job); MessageConsumer messageConsumer = consumer.getSession().createConsumer(destination); messageConsumer.setMessageListener(new MyMessageListener(job)); }

Appendix

IBM MQSeries (1/3) Basic concepts: Message transfer: Application-specific messages are put into, and removed from queues Queues always reside under the regime of a queue manager Processes can put messages only in local queues, or through an RPC mechanism Message transfer: Messages are transferred between queues Message transfer between queues at different processes, requires a channel At each endpoint of channel is a message channel agent (MCA) Setting up channels using lower-level network communication facilities (e.g., TCP/IP) (Un)wrapping messages from/in transport-level packets Sending/receiving packets

IBM MQSeries (2/3) Channels are inherently unidirectional MQSeries provides mechanisms to automatically start MCAs when messages arrive, or to have a receiver set up a channel Any network of queue managers can be created; routes are set up manually (system administration)

IBM MQSeries (3/3) Routing: By using logical names, in combination with name resolution to local queues, it is possible to put a message in a remote queue Question: What’s a major problem here?

Message Broker Observation: Message queuing systems assume a common messaging protocol: all applications agree on message format (i.e., structure and data representation) Message broker: Centralized component that takes care of application heterogeneity in a message-queuing system: Transforms incoming messages to target format, possibly using intermediate representation May provide subject-based routing capabilities Acts very much like an application gateway

IBM MQSeries One-to-one reliable message passing using queues Persistent and non-persistent messages Message priorities, message notification Queue Managers Responsible for queues Transfer messages from input to output queues Keep routing tables Message Channels Reliable connections between queue managers Messaging API: MQopen Open a queue MQclose Close a queue MQput Put message into opened queue MQget Get message from local queue

Java Message Service (JMS) API specification to access MOM implementations Two modes of operation *specified*: Point-to-point one-to-one communication using queues Publish/Subscribe cf. Event-Based Middleware JMS Server implements JMS API JMS Clients connect to JMS servers Java objects can be serialised to JMS messages A JMS interface has been provided for MQ pub/sub (one-to-many) - just a specification?