JMS Binding

Configuration reference for the JMS message bus binding.

Overview

The JMS binding works with JMS 1.1 level JMS clients and is configured using JNDI lookup. The platform also provides provider-specific implementations optimized for ActiveMQ and Tibco EMS.

For conceptual information about the JMS binding, see JMS Binding.

Bus Descriptor Format

JMS buses can be configured using a descriptor string or decomposed DDL format.

Descriptor String

jms://<address>:<port>&prop1=val1&propN=valN

Example (Tibco EMS):

jms://tibcohost:2732&username=admin&password=changeme&jndi=true&jndi_contextfactory=com.tibco.tibjms.naming.TibjmsInitialContextFactory&jndi_principal=admin&jndi_credentials=changme&jndi_connectionfactory=CSTopicConnectionFactory

Decomposed DDL Format

<buses>
  <bus name="my-bus">
    <provider>jms</provider>
    <address>192.168.1.9</address>
    <port>55555</port>
    <properties>
      <username>admin</username>
      <password>changeme</password>
      <jndi>true</jndi>
      <jndi_contextfactory>com.tibco.tibjms.naming.TibjmsInitialContextFactory</jndi_contextfactory>
      <jndi_principal>admin</jndi_principal>
      <jndi_credentials>changme</jndi_credentials>
      <jndi_connectionfactory>CSTopicConnectionFactory</jndi_connectionfactory>
    </properties>
    <channels>
      <!-- channel configuration -->
    </channels>
  </bus>
</buses>

As Descriptor (Substitution Support)

The descriptor form is useful when the descriptor is supplied as an external configuration property:

Generic JMS Binding Properties

The following properties can be set in the descriptor used to create a JMS bus binding.

Property
Default
Description

jndi

true

Indicates that JNDI should be used to lookup the connection factory for creating JMS connections.

When using JNDI, the address portion of the binding descriptor is used as the address at which to lookup the connection factory. The returned connection factory may connect to a different host.

jndi_contextfactory

-

The name of the environment property for specifying the initial context factory to use.

jndi_principal

-

The name of the environment property for specifying the identity of the principal for authenticating the caller to the service.

jndi_credentials

-

The environment property for specifying the credentials of the principal for authenticating the caller to the service.

jndi_connectionfactory

-

The name of the connection factory to look up in JNDI.

username

-

The username to supply in the credentials when opening the JMS connection.

password

-

The password to supply in the credentials when opening the JMS connection.

set_client_id

true

Specifies whether a client_id should be set for the connection. When true, Connection.setClientID(String) is set on the JMS connection. It is important that the client id be set when using Guaranteed QoS subscriptions as the durable subscriptions issued by the binding are tied to the ClientID. When set to true, the client id X-SMA-<busname>-<bususer> will be used as the JMS ClientID unless use_legacy_client_id or client_id are set. Note that the bususer value used in the ClientID is the username supplied during bus creation to identify the logical bus user, not the username used in the credentials for connecting to the JMS broker.

use_legacy_client_id

false

Specifies that the legacy client id should be used. When set to true indicates that the default client id of <bususer>-<busname> should be used rather than the default X-SMA-<busname>-<bususer>. This property is ignored if set_client_id is false or client_id is used to set an explicit JMS ClientID. This property should only be set for applications that were using the activemq bus provider in 3.7 or earlier. Since 3.8

client_id

-

Can be used to specify a specific client id for the bus. This property can be used to override the default client id when set_client_id is set to true.

Since 3.8

connection_open_retry_count

10

Property controlling number of retries to attempt after a failure to open a connection. When a connection attempt fails with a reason that isn't known to be a permanent condition, this property controls the number of reconnect attempts to try. Reconnect attempts will be attempted at the interval specified by connection_open_retry_interval. Since 3.8

connection_open_retry_interval

1s

Property specifying the retry interval for connection open retries in seconds. When no time unit suffix is provided for this value it is interpreted as the number of seconds between retries. Otherwise, a time suffix can be provided to qualify the unit as specified in UtlUnit.parseDuration(String, TimeUnit, TimeUnit). The minimum allowable value for retries is 250ms, specifying a lower value will cause it to be rounded up. Since 3.8

Provider Specific Implementations

ActiveMQ

While ActiveMQ can be configured via JNDI like any other JMS provider, the platform provides a custom activemq bus provider.

The ActiveMQ binding is additionally optimized to:

  • Use ActiveMQ's INDIVIDUAL_ACKNOWLEDGE_MODE for channels using Guaranteed delivery

  • Normalize subscribe and send calls to replace / delimited topics with . delimited topics which allows the same channel key configuration as other platform bindings

Decomposed DDL Format

As Descriptor

Binding Specific Properties

The ActiveMQ binding does not have any binding-specific properties beyond the Generic JMS Binding Properties listed above.

Tibco EMS

Since 3.8

While Tibco EMS can be configured via JNDI like any other JMS provider, the platform provides a custom tibems bus provider.

The Tibco EMS binding is additionally optimized to:

  • Use Tibco EMS' EXPLICIT_CLIENT_ACKNOWLEDGE for channels using Guaranteed delivery

  • Normalize subscribe and send calls to replace / delimited topics with . delimited topics which allows the same channel key configuration as other platform bindings

Decomposed DDL Format

As Descriptor

Binding Specific Properties

The Tibco EMS binding does not have any binding-specific properties beyond the Generic JMS Binding Properties listed above.

See Also

Last updated