Sun Java System Message Queue 4.1 Technical Overview

Feature List

Table B–1 Message Queue Features

Feature 

Description and Reference 

Administration tools 

The Message Queue service includes GUI and command line tools for managing destinations, transactions, durable subscriptions, administered object stores, user repositories, JDBC-compliant data stores, and server certificates. 

Reference

Administration Tools.

Chapter 1, Administrative Tasks and Tools, in Sun Java System Message Queue 4.1 Administration Guide

Authentication 

Authenticate users seeking a connection to the broker.

The Message Queue service allows users to connect to the broker by validating their name and password against values stored in a user repository. The repository can be a flat-file repository shipped with Message Queue or an LDAP repository (LDAP v2 or v3 protocol). 

To Use

  1. Create a user repository or use the default instance.

  2. Use the imqusermgr tool to populate the repository.

JAAS-Based Authentication

Application clients can also use authentication services based on the Java Authentication and Authorization Service (JAAS), which allows you to plug in a variety of services into the broker to authenticate Message Queue clients. The JAAS API is a core API in J2SE and therefore it is an integral part of Message Queue's runtime environment. 

To Use

  1. The JAAS provider supplies a login module class that implements the authentication service.

  2. Obtain JAAS configuration file and specify its location using a system property.

  3. Configure broker properties that relate to JAAS support.

Reference

Authentication and Authorization.

Chapter 9, Security, in Sun Java System Message Queue 4.1 Administration Guide.

Authorization 

Authorize users to perform specific operations.

The Message Queue service allows you to create an access control properties file that specifies the operations users and groups of users can perform. The broker checks this file when a client seeks to create a connection, create a producer, create a consumer, or browse a queue. 

To Use

Edit the access control properties file that is automatically created for the broker instance. 

Reference

Authentication and Authorization

Chapter 9, Security, in Sun Java System Message Queue 4.1 Administration Guide.

Automatic reconnect 

The administrator sets connection attributes on the connection factory administered object to enable automatic reconnection in the event of connection failure. Reconnection can be to the same broker or to another broker in a cluster if a cluster is used. You can specify how many times to try reconnection and the interval between attempts. For clustered brokers, you can also specify how often to iterate through a list of brokers and whether to iterate through the list in a specific order.

Reference

Connection Services.

Chapter 7, Administered Objects, in Sun Java System Message Queue 4.1 Administration Guide.

Broker clusters 

The administrator can balance client connections and message delivery across a number of broker instances by grouping those instances into a broker cluster. The Message Queue service supports two kinds of clusters: conventional clusters and high availability clusters

To Use Conventional Clusters

  1. Specify cluster configuration properties for each broker in the cluster. Specify properties that are the same for all brokers using a cluster configuration file.

  2. If there is a master broker, start the master broker

  3. Start the other brokers in the cluster.

To Use High Availability Clusters

  1. Specify cluster configuration properties for each broker in the cluster (including JDBC-related properties). Specify properties that are the same for all brokers using a cluster configuration file.

  2. Install your JDBC driver's .jar file in the appropriate directory location.

  3. Use the imqdbmgr tool to create the database schema for the highly available data store.

  4. Start the brokers in the cluster.

Reference

Chapter 4, Broker Clusters

Chapter 8, Broker Clusters, in Sun Java System Message Queue 4.1 Administration Guide.

Broker configuration 

The administrator can set broker properties to tune Message Queue service performance. This includes routing services, persistence services, security, monitoring, and administered object management. 

Reference

Chapter 3, Message Queue Service

Chapter 4, Broker Configuration, in Sun Java System Message Queue 4.1 Administration Guide

C client support 

C clients can use Message Queue messaging services to send and receive messages. The C API enables legacy C applications and C++ applications to participate in JMS-based messaging. 

Message Queue’s C API is supported by a C client runtime that supports most of the standard JMS functionality, with the exception of the following: the use of administered objects; map, stream, or object message body types; distributed transactions; and queue browsers. The C client runtime also does not support most of Message Queue’s enterprise features.

Reference

Java and C Clients.

Sun Java System Message Queue 4.1 Developer’s Guide for C Clients

Client runtime logging 

Java clients can use all the J2SE 1.4 logging facilities to configure how the Message Queue client runtime outputs its logging information. Clients can choose to log the following events: changes in connection state and miscellaneous connection activities, session-related events, the creation of producers, consumers, and destinations, and the consumption and production of messages.  

Java clients can configure logging programmatically or by using configuration files. 

Reference

Client Runtime Logging in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients

Compressed messages 

Java clients can set a message property to have the client runtime compress a message being sent. The runtime on the consumer side decompresses the message before it delivers it to the consumer. Additional properties are provided that you can use to determine whether compressing messages would actually improve performance.

Reference

Message Body.

Managing Message Size in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients.

Configurable persistence 

The administrator can configure the broker to use the file-based persistent store provided with Message Queue or a JDBC-compliant database, such as Oracle 8i.

To Use

Set broker properties that relate to file-system persistent storage or JDBC-compliant storage. 

Reference

Persistence Services.

Configuring a Persistent Data Store in Sun Java System Message Queue 4.1 Administration Guide.

Configurable physical destinations 

The administrator can define some messaging behavior by setting physical destination properties when creating destinations. The following behavior can be configured for any destination: the maximum number of unconsumed messages or the maximum amount of memory allowed for such messages, which messages the broker should reject when memory limits are reached, the maximum number of producers and consumers, the maximum message size, the maximum number of messages delivered in a single batch, whether the destination can deliver only to local consumers, and whether dead messages on the destination can be moved to the dead message queue. 

Reference

Destinations and Routing Services.

Chapter 6, Physical Destinations, in Sun Java System Message Queue 4.1 Administration Guide.

Connection ping 

The administrator can set a connection factory attribute to specify the frequency of a ping operation from the client runtime to the broker. This allows the client to preemptively detect a failed connection.

Reference

Connection Services.

Connection Services in Sun Java System Message Queue 4.1 Administration Guide.

Dead message queue 

The Message Queue message service creates the dead message queue to hold messages that have expired or that the broker could not process. You can examine the contents of the queue to monitor, tune, or troubleshoot system performance.

Reference

Destinations and Routing Services.

Chapter 6, Physical Destinations, in Sun Java System Message Queue 4.1 Administration Guide.

Event Notification 

Java clients can listen for connection events (like closure or reconnection) and take appropriate action based on the notification type and the connection state.  

To Use

  1. Use the event notification API to create an event listener.

  2. Add code to the client application that will take appropriate action depending on the events captured by the event listener.

Reference

Connection Event Notification in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients

HTTP connections 

Java clients can create HTTP connections to the broker.

HTTP transport allows messages to be delivered through firewalls. Message Queue implements HTTP support using an HTTP tunnel servlet that runs in a web server environment. Messages produced by a client are wrapped by the client runtime as HTTP requests and delivered over HTTP through a firewall to the tunnel servlet. The tunnel servlet extracts the JMS message from the HTTP request and delivers the message over TCP/IP to the broker. 

To Use

  1. Deploy HTTP tunnel servlet on a web server.

  2. Configure broker’s httpjms connection service and start the broker.

  3. Configure HTTP connection.

  4. Obtain an HTTP connection to the broker. (Java clients only.)

Reference

Connecting to the Broker.

Appendix C, HTTP/HTTPS Support, in Sun Java System Message Queue 4.1 Administration Guide

Interactive monitoring 

The administrator can use the imqcmd metrics command to monitor a broker remotely. Monitored data includes JVM metrics, broker message flow, connections, connection resources, messages, destination message flow, destination consumers, destination resource use.

Reference

Monitoring Services.

Chapter 10, Monitoring Broker Operations, in Sun Java System Message Queue 4.1 Administration Guide

J2EE resource adapters 

Message Queue provides a resource adapter that can be plugged into a J2EE-compliant application server. By using Message Queue as a JMS provider, an application server meets the J2EE requirement that distributed components running in the application server be able to interact using reliable, asynchronous message.

To Use

Configure the adapter by setting adapter attributes. 

Reference

J2EE Application Server Support.

Chapter 17, JMS Resource Adapter Property Reference, in Sun Java System Message Queue 4.1 Administration Guide.

JES Monitoring Framework support 

The JES Monitoring Framework allows administrators to use the same interface to manage any and all JES components. If you are using Message Queue with other JES components, it might be more convenient to manage these from a single console. Administrators can use the Sun Java System Monitoring Console to view performance statistics, create rules to monitor automatically, and acknowledge alarms. To enable JES monitoring, you must do the following:

  • Install and configure the components in your deployment; for example, Message Queue and the Application Server.

  • Enable and configure the Monitoring Framework for all your monitored components.

  • Install the Monitoring Console on a separate host, start the master agent, and then start the web server.

For information, see the Sun Java Enterprise System Monitoring Guide.

JMX-Based Administration 

Java clients can use the JMX API to monitor and manage broker resources: the broker, services, connections, destinations, consumers, producers, and so on. You can use JMX-based management in different ways to monitor application performance, to monitor the broker, to automate tasks, or to write custom tools. 

Reference

Sun Java System Message Queue 4.1 Developer’s Guide for JMX Clients

JNDI service provider support 

Clients can look up administered objects using the JNDI API. 

Administrators can use the imqobjmgr utility to add, list, update, and delete administered objects in an object store accessible using JNDI.

Reference

Administration Tools

Chapter 7, Administered Objects, in Sun Java System Message Queue 4.1 Administration Guide

LDAP Server support 

The administrator can use LDAP servers for administered object store and for storing user information needed for authentication and authorization. By default Message Queue provides file-based storage for this data. 

To Use for Administered Objects

  1. Use the tools provided by the vendor to populate and manage the user repository.

  2. Set the LDAP-related broker properties.

  3. Set up access control for administrative users.

Reference

Security Services.

Chapter 9, Security, in Sun Java System Message Queue 4.1 Administration Guide

To Use for User Repository

  1. Use the tools provided by the vendor to set up the LDAP server.

  2. Set the LDAP-related broker properties to define the initial context and the location of the store.

  3. Set the LDAP-related broker properties that relate to securing the LDAP server operations.

Reference

Chapter 9, Security, in Sun Java System Message Queue 4.1 Administration Guide

Memory resource management 

The administrator can configure the following behavior:

  1. Set properties on a destination to specify the maximum number of producers, the maximum number of messages, and the maximum size of any one message.

  2. Set properties on a destination to control message flow.

  3. Set properties on a destination to manage message flow for each destination.

  4. Set properties on the broker to specify message limits on all destinations for that broker.

  5. Set properties on the broker to specify thresholds of available system memory at which the broker takes action to prevent memory overload. The action taken depends on the state of memory resources.

Reference

Destinations and Routing Services.

Chapter 4, Broker Configuration, in Sun Java System Message Queue 4.1 Administration Guide

Message compression 

The developer can set a message header property to have the client runtime compress a message before sending it. The client runtime on the consumer side decompresses the message before delivering it to the consumer.

Reference

Message Properties.

Message Compression in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients

Message flow control to clients 

The administrator or the developer can configure a connection to specify various flow limits and metering schemes to minimize the collision of payload and control messages, and thereby to maximize message throughput.

To Use

Set the flow-control attributes for the connection factory administered object (administrator), or set the flow-control properties for the connection factory (developer). 

Reference

Connection Factories and Connections.

Connection Services in Sun Java System Message Queue 4.1 Administration Guide.

Connection Factory Attributes in Sun Java System Message Queue 4.1 Administration Guide

Message-based monitoring API 

Java clients can use a monitoring API to create custom monitoring applications. A monitoring application is a consumer that retrieves metrics messages from special metrics topic destinations.

To Use

  1. Write a metrics monitoring client.

  2. Set broker properties to configure the broker’s metrics message producer.

  3. Set access controls on metrics topic destinations.

  4. Start the monitoring client.

Reference

Monitoring Services.

Chapter 4, Using the Metrics Monitoring API, in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients.

Chapter 10, Monitoring Broker Operations, in Sun Java System Message Queue 4.1 Administration Guide.

Queue delivery to multiple consumers 

Clients can register more than one consumer for a given queue.

The administrator can specify the maximum number of active consumers and the maximum number of backup consumers for the queue. The broker distributes messages to the registered consumers, balancing the load among them in order to allow the system to scale. 

To Use

Set physical destination properties maxNumActiveConsumers and maxNumBackupConsumers.

Reference

Point-To-Point Messaging.

Chapter 15, Physical Destination Property Reference, in Sun Java System Message Queue 4.1 Administration Guide.

Reliable data persistence 

To obtain absolute reliability you can require that the operating system write the data synchronously to the persistent store by setting the imq.persist.file.sync.enabled property to true. This eliminates possible data loss due to system crashes, but at the expense of performance. Note that although the data is not lost, it is not available to any other broker (in a cluster) because data is not currently shared by clustered brokers. When the system comes back up, the broker can reliably resume operations.

Reference

Persistence Services.

Persistence Properties in Sun Java System Message Queue 4.1 Administration Guide

Secure connections 

Clients can secure transmission of messages using the Secure Socket Layer (SSL) standard over TCP/IP and HTTP transports. These SSL-based connection services allow for the encryption of messages sent between clients and broker. 

SSL support is based on self-signed server certificates. Message Queue provides a utility that generates a private/public key pair and embeds the public key in a self-signed certificate. This certificate is passed to any client requesting a connection to the broker, and the client uses the certificate to set up an encrypted connection.

To Use

  1. Generate a self-signed or signed certificate.

  2. Enable the secure service.

  3. Start the broker.

  4. Configure client security connection properties and run the client.

Reference

Connecting to the Broker.

Security Services.

Chapter 9, Security, in Sun Java System Message Queue 4.1 Administration Guide.

Working With Secure Connections in Sun Java System Message Queue 4.1 Developer’s Guide for C Clients

SOAP support 

Clients can receive SOAP (XML) messages and they can wrap them as JMS messages and use Message Queue to exchange them as they would a JMS message.

Clients can use a special servlet to receive SOAP messages; they can use a utility class to wrap a SOAP message as a JMS message; they can use another utility class to extract the SOAP message from the JMS message. Clients can use standard SAAJ libraries to assemble and disassemble a SOAP message. 

Reference

Working with SOAP Messages.

“Working With SOAP Message,” Chapter 5, Working with SOAP Messages, in Sun Java System Message Queue 4.1 Developer’s Guide for Java Clients.

Thread management 

The administrator can specify the maximum and minimum number of threads assigned to any specific connection service. The administrator can also determine whether a connection service could increase throughput by using a shared thread model, which allows threads dedicated to idle connections to be used by other connections.

To Use

Set connection service thread-related properties. 

Reference

Thread Pool Management.

Chapter 4, Broker Configuration, in Sun Java System Message Queue 4.1 Administration Guide.

Tunable performance 

The administrator can set broker properties to adjust memory usage, threading resources, message flow, connection services, reliability parameters, and other elements that affect message throughput and system performance.

Reference

Monitoring Services.

Monitoring Services in Sun Java System Message Queue 4.1 Administration Guide

Chapter 11, Analyzing and Tuning a Message Service, in Sun Java System Message Queue 4.1 Administration Guide