3.6. Configuring the JMS Client

The Qpid JMS Client allows several configuration options to customize it's behaviour at different levels of granualarity.

Some of these config options are available at all three levels (Ex. max_prefetch), while others are available only at JVM or connection level.

3.6.1. Qpid JVM Arguments

Table 3.6. Config Options For Connection Behaviour

Property NameTypeDefault ValueDescription
qpid.amqp.versionstring0-10Sets the AMQP version to be used - currently supports one of {0-8,0-9,0-91,0-10}
qpid.heartbeatint120 (secs)The heartbeat interval in seconds. Two consective misssed heartbeats will result in the connection timing out.

This could also be set per connection as well (see connection paramters).

ignore_setclientIDbooleanfalseIf a client ID is specified in the connection URL it's used or else an ID is generated. If an ID is specified after it's been set Qpid will throw an exception.

Setting this property to 'true' will disable that check and allow you to set a client ID of your choice later on.


Table 3.7. Config Options For Session Behaviour

Property NameTypeDefault ValueDescription
qpid.session.command_limitint65536Limits the # of unacked commands
qpid.session.byte_limitint1048576Limits the # of unacked commands in terms of bytes
qpid.use_legacy_map_messagebooleanfalse

If set will use the old map message encoding. By default the Map messages are encoded using the 0-10 map encoding.

This could also be set per connection as well (see connection paramters).


Table 3.8. Config Options For Consumer Behaviour

Property NameTypeDefault ValueDescription
max_prefetchint500Maximum number of messages to credits.

This could also be set per connection (see connection paramters) or per destination (see the capacity option under link properties in addressing).

qpid.session.max_ack_delaylong1000 (ms)

Timer interval to flush message acks in buffer when using AUTO_ACK and DUPS_OK.

When using the above ack modes, message acks are batched and sent if one of the following conditions are met (which ever happens first).

  • When the ack timer fires.

  • if un_acked_msg_count > max_prefetch/2.

The ack timer can be disabled by setting it to 0.

sync_ackbooleanfalse

If set, each message will be acknowledged synchronously. When using AUTO_ACK mode, you need to set this to "true", in order to get the correct behaviour as described by the JMS spec.

This is set to false by default for performance reasons, therefore by default AUTO_ACK behaves similar to DUPS_OK.

This could also be set per connection as well (see connection paramters).


Table 3.9. Config Options For Producer Behaviour

Property NameTypeDefault ValueDescription
sync_publishstring"" (disabled)

If one of {persistent|all} is set then persistent messages or all messages will be sent synchronously.

This could also be set per connection as well (see connection paramters).


Table 3.10. Config Options For Threading

Property NameTypeDefault ValueDescription
qpid.thread_factorystringorg.apache.qpid.thread.DefaultThreadFactory

Specifies the thread factory to use.

If using a real time JVM, you need to set the above property to org.apache.qpid.thread.RealtimeThreadFactory.

qpid.rt_thread_priorityint20

Specifies the priority (1-99) for Real time threads created by the real time thread factory.


Table 3.11. Config Options For I/O

Property NameTypeDefault ValueDescription
qpid.transportstringorg.apache.qpid.transport.network.io.IoNetworkTransport

The transport implementation to be used.

A user could specify an alternative transport mechanism that implements the org.apache.qpid.transport.network.NetworkTransport interface.

amqj.tcp_nodelaybooleanfalse

Sets the TCP_NODELAY property of the underlying socket.

This could also be set per connection as well (see connection paramters).


Table 3.12. Config Options For Security

Property NameTypeDefault ValueDescription
qpid.sasl_mechsstringPLAIN

The SASL mechanism to be used. More than one could be specified as a comma separated list.

We currently support the following mechanisms {PLAIN | GSSAPI | EXTERNAL}.

This could also be set per connection as well (see connection paramters).

qpid.sasl_protocolstringAMQP

When using GSSAPI as the SASL mechanism, sasl_protocol must be set to the principal for the qpidd broker, e.g. qpidd.

This could also be set per connection as well (see connection paramters).

qpid.sasl_server_namestringlocalhost

When using GSSAPI as the SASL mechanism, sasl_server must be set to the host for the SASL server, e.g. example.com.

This could also be set per connection as well (see connection paramters).


Table 3.13. Config Options For Security - Standard JVM properties needed when using GSSAPI as the SASL mechanism.[a]

Property NameTypeDefault ValueDescription
javax.security.auth.useSubjectCredsOnlybooleantrue

If set to 'false', forces the SASL GASSPI client to obtain the kerberos credentials explicitly instead of obtaining from the "subject" that owns the current thread.

java.security.auth.login.configstring 

Specifies the jass configuration file.

Ex-Djava.security.auth.login.config=myjas.conf

Here is the sample myjas.conf JASS configuration file:


    com.sun.security.jgss.initiate {
        com.sun.security.auth.module.Krb5LoginModule required useTicketCache=true;
    };

[a] Please refer to the Java security documentation for a complete understanding of the above properties.


Table 3.14. Config Options For Security - Using SSL for securing connections or using EXTERNAL as the SASL mechanism.

Property NameTypeDefault ValueDescription
qpid.ssl_timeoutlong60000

Timeout value used by the Java SSL engine when waiting on operations.

qpid.ssl.keyStoreCertTypestringSunX509

The certificate type.

This could also be set per connection as well (see connection paramters).

qpid.ssl.trustStoreCertTypestringSunX509

The certificate type.

This could also be set per connection as well (see connection paramters).


Table 3.15. Config Options For Security - Standard JVM properties needed when Using SSL for securing connections or using EXTERNAL as the SASL mechanism.[a]

Property NameTypeDefault ValueDescription
javax.net.ssl.keyStorestringjvm default

Specifies the key store path.

This could also be set per connection as well (see connection paramters).

javax.net.ssl.keyStorePasswordstringjvm default

Specifies the key store password.

This could also be set per connection as well (see connection paramters).

javax.net.ssl.trustStorestringjvm default

Specifies the trust store path.

This could also be set per connection as well (see connection paramters).

javax.net.ssl.trustStorePasswordstringjvm default

Specifies the trust store password.

This could also be set per connection as well (see connection paramters).

[a] Qpid allows you to have per connection key and trust stores if required. If specified per connection, the JVM arguments are ignored.