Message queuing terminology
This information gives an insight into some terms used in message queuing.
They include:- Message
- Message descriptor
- Queue
- Queue manager
- Channels
- Message channel agent
- Cluster
- Shared queue
- Queue sharing group
- Intra-group queuing
- IBM MQ MQI client
- Point-to-point
- Publish/subscribe
- Topic
- Subscription
- Message
-
In message queuing, a message is a collection of data sent by one program and intended for another program. See IBM MQ messages. For information about message types, see Types of message.
- Message descriptor
-
An IBM MQ message consists of control information and application data.
The control information is defined in a message descriptor structure (MQMD) and contains such things as:- The type of the message
- An identifier for the message
- The priority for delivery of the message
The structure and content of the application data is determined by the participating programs, not by IBM MQ.
- Queue
-
A named destination to which messages can be sent. Messages accumulate on queues until they are retrieved by programs that service those queues.
- Queue manager
-
A queue manager is a system program that provides queuing services to applications.
It provides an application programming interface so that programs can put messages on, and get messages from, queues. A queue manager provides additional functions so that administrators can create new queues, alter the properties of existing queues, and control the operation of the queue manager.
For IBM MQ message queuing services to be available on a system, there must be a queue manager running. We can have more than one queue manager running on a single system (for example, to separate a test system from a live system). To an application, each queue manager is identified by a connection handle (Hconn).
Many different applications can use the services of the queue manager at the same time and these applications can be entirely unrelated. For a program to use the services of a queue manager, it must establish a connection to that queue manager.
For applications to send messages to applications that are connected to other queue managers, the queue managers must be able to communicate among themselves. IBM MQ implements a store-and-forward protocol to ensure the safe delivery of messages between such applications.
- Channels
-
Channels are objects that provide a communication path from one queue manager to
another. Channels are used to move messages from one queue manager to another and they shield
applications from the underlying communications protocols. The queue managers might exist on the
same system, or a different systems on the same platform, or on different platforms. The messages
that are sent can originate from many places:
- User-written application programs that transfer data from one node to another.
- User-written administration applications that use PCF commands or the MQAI.
- The IBM MQ Explorer.
- Queue managers that send instrumentation event messages to another queue manager.
- Queue managers that send remote administration commands to another queue manager. For example, using MQSC commands or the administrative REST API.
- Message channel agent
-
A message channel agent is one end of a channel. A pair of message channel agents, one sending and one receiving, make up a channel and move messages from one queue manager to another.
- Cluster
-
A cluster is a network of queue managers that are logically associated in some way.
In an IBM MQ network using distributed queuing without clustering, every queue manager is independent. If one queue manager needs to send messages to another, it must have defined a transmission queue and a channel to the remote queue manager.
There are two different reasons for using clusters: to reduce system administration and to improve availability and workload balancing.
As soon as you establish even the smallest cluster, you benefit from simplified system administration. Queue managers that are part of a cluster need fewer definitions and so the risk of making an error in your definitions is reduced.
For more information about clustering, see Clusters.
-
A shared queue is a type of local queue with messages that can be accessed by one or more queue managers that are in a sysplex. This is not the same as a queue being shared by more than one application, using the same queue manager. This applies only to IBM MQ for z/OS .
- Queue sharing group
-
The queue managers that can access the same set of shared queues form a group called a queue sharing group (QSG). They communicate with each other with a coupling facility (CF) that stores the shared queues. This applies only to IBM MQ for z/OS. See Shared queues and queue sharing groups for more information about queue sharing groups.
- Intra-group queuing
-
Queue managers in a queue sharing group can communicate using normal channels or we can use a technique called intra-group queuing (IGQ), which lets you perform fast message transfer without defining channels. This applies only to IBM MQ for z/OS.
- IBM MQ MQI client
-
IBM MQ MQI clients are independently installable components of IBM MQ. An MQI client allows you to run IBM MQ applications with a communications protocol, to interact with one or more Message Queue Interface (MQI) servers on other platforms and to connect to their queue managers.
For full details on how to install and use IBM MQ MQI client components, see the following topics: - Point-to-point messaging
-
In point-to-point messaging, each message travels from one producing application to one consuming application. Messages are transferred through the producing application putting messages onto a queue and the consuming application gets them from that queue.
- Publish/subscribe messaging
-
In publish/subscribe messaging, a copy of each message published by a publishing application is delivered to every interested application. There might be many, one or no interested applications. In publish/subscribe an interested application is known as a subscriber and the messages are queued on a queue identified by a subscription. For more information, see Publish/subscribe messaging.
- Topic
-
A topic is a character string that describes the subject of the information that is published in a publish/subscribe message.
Topics are key to the successful delivery of messages in a publish/subscribe system. Instead of including a specific destination address in each message, a publisher assigns a topic to each message. The queue manager matches the topic with a list of subscribers who have subscribed to that topic, and delivers the message to each of those subscribers.
- Subscription
-
A publish/subscribe application can register an interest in messages about specific topics. When an application does this it is known as a subscriber and the term subscription defines how matching messages are queued for processing.
A subscription contains information about the identity of the subscriber and the identity of the destination queue on to which publications are to be placed. It also contains information about how a publication is to be placed on the destination queue.
Parent topic: Introduction to message queuing