Fuse 6 is no longer supported
As of February 2025, Red Hat Fuse 6 is no longer supported. If you are using Fuse 6, please upgrade to Red Hat build of Apache Camel.此内容没有您所选择的语言版本。
14.2. Using the JMS configuration bean
Overview
复制链接链接已复制到粘贴板!
					To simplify JMS configuration and make it more powerful, Apache CXF uses a single JMS configuration bean to configure JMS endpoints. The bean is implemented by the 
org.apache.cxf.transport.jms.JMSConfiguration class. It can be used to either configure endpoint's directly or to configure the JMS conduits and destinations.
				Configuration namespace
复制链接链接已复制到粘贴板!
					The JMS configuration bean uses the Spring p-namespace to make the configuration as simple as possible. To use this namespace you need to declare it in the configuration's root element as shown in Example 14.1, “Declaring the Spring p-namespace”.
				
Example 14.1. Declaring the Spring p-namespace
<beans ... xmlns:p="http://www.springframework.org/schema/p" ... > ... </beans>
<beans ...
  xmlns:p="http://www.springframework.org/schema/p"
  ... >
  ...
</beans>Specifying the configuration
复制链接链接已复制到粘贴板!
					You specify the JMS configuration by defining a bean of class 
org.apache.cxf.transport.jms.JMSConfiguration. The properties of the bean provide the configuration settings for the transport.
				Important
						In CXF 3.0, the JMS transport no longer has a dependency on Spring JMS, so some Spring JMS-related options have been removed.
					
					Table 14.1, “General JMS Configuration Properties” lists properties that are common to both providers and consumers.
				
| Property | Default | Description | 
|---|---|---|
| connectionFactory | [Required] Specifies a reference to a bean that defines a JMS ConnectionFactory. | |
| wrapInSingleConnectionFactory | true[pre v3.0] | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies whether to wrap the  ConnectionFactorywith a SpringSingleConnectionFactory.
									Enable this property when using a  ConnectionFactorythat does not pool connections, as it will improve the performance of the JMS transport. This is so because the JMS transport creates a new connection for each message, and theSingleConnectionFactoryis needed to cache the connection, so it can be reused. | 
| reconnectOnException | false | 
									[Deprecated in CXF 3.0] CXF always reconnects when an exception occurs.
								 
									[pre CXF 3.0] Specifies whether to create a new connection when an exception occurs.
								 
									When wrapping the  ConnectionFactorywith a SpringSingleConnectionFactory:
 | 
| targetDestination | Specifies the JNDI name or provider-specific name of a destination. | |
| replyDestination | Specifies the JMS name of the JMS destination where replies are sent. This property allows the use of a user-defined destination for replies. For more details see Section 14.6, “Using a Named Reply Destination”. | |
| destinationResolver | DynamicDestinationResolver | 
									Specifies a reference to a Spring  DestinationResolver.
									This property allows you to define how destination names are resolved to JMS destinations. Valid values are: 
									 
 | 
| transactionManager | Specifies a reference to a Spring transaction manager. This enables the service to participate in JTA transactions. | |
| taskExecutor | SimpleAsyncTaskExecutor | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies a reference to a Spring  TaskExecutor. This is used in listeners to decide how to handle incoming messages. | 
| useJms11 | false | 
									[Removed in CXF 3.0] CXF 3.0 supports JMS 1.1 features only.
								 
									[pre CXF 3.0] Specifies whether JMS 1.1 features are used. Valid values are: 
									 
 | 
| messageIdEnabled | true | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies whether the JMS transport wants the JMS broker to provide message IDs. Valid values are: 
									 
 | 
| messageTimestampEnabled | true | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies whether the JMS transport wants the JMS broker to provide message time stamps. Valid values are: 
									 
 | 
| cacheLevel | -1(feature disabled) | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies the level of caching that the JMS listener container may apply. Valid values are: 
									 
 
									For details, see Class DefaultMessageListenerContainer
								 | 
| pubSubNoLocal | false | 
									Specifies whether to receive your own messages when using topics. 
									 
 | 
| receiveTimeout | 60000 | Specifies the time, in milliseconds, to wait for response messages. | 
| explicitQosEnabled | false | Specifies whether the QoS settings (such as priority, persistence, time to live) are explicitly set for each message ( true) or use the default values (false). | 
| deliveryMode | 2 | 
									Specifies whether a message is persistent. Valid values are:
								 
 | 
| priority | 4 | Specifies message priority. JMS priority values range from 0(lowest) to9(highest). See your JMS provider's documentation for details. | 
| timeToLive | 0(indefinitely) | Specifies the time, in milliseconds, before a message that has been sent is discarded. | 
| sessionTransacted | false | Specifies whether JMS transactions are used. | 
| concurrentConsumers | 1 | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies the minimum number of concurrent consumers for the listener.
								 | 
| maxConcurrentConsumers | 1 | 
									[Removed in CXF 3.0]
								 
									[pre CXF 3.0] Specifies the maximum number of concurrent consumers for the listener.
								 | 
| messageSelector | Specifies the string value of the selector used to filter incoming messages. This property enables multiple connections to share a queue. For more information on the syntax used to specify message selectors, see the JMS 1.1 specification. | |
| subscriptionDurable | false | Specifies whether the server uses durable subscriptions. | 
| durableSubscriptionName | Specifies the name (string) used to register the durable subscription. | |
| messageType | text | 
									Specifies how the message data will be packaged as a JMS message. Valid values are: 
									 
 | 
| pubSubDomain | false | 
									Specifies whether the target destination is a topic or a queue. Valid values are: 
									 
 | 
| jmsProviderTibcoEms | false | 
									Specifies whether the JMS provider is Tibco EMS.
								 
									When set to  true, the principal in the security context is populated from theJMS_TIBCO_SENDERheader. | 
| useMessageIDAsCorrelationID | false | 
									[Removed in CXF 3.0]
								 
									Specifies whether JMS will use the message ID to correlate messages.
								 
									When set to  true, the client sets a generated correlation ID. | 
| maxSuspendedContinuations | -1(feature disabled) | 
									[CXF 3.0] Specifies the maximum number of suspended continuations the JMS destination may have. When the current number exceeds the specified maximum, the JMSListenerContainer is stopped.
								 | 
| reconnectPercentOfMax | 70 | 
									[CXF 3.0] Specifies when to restart the JMSListenerContainer stopped for exceeding  maxSuspendedContinuations.
									The listener container is restarted when its current number of suspended continuations falls below the value of  (maxSuspendedContinuations * reconnectPercentOfMax/100). | 
					As shown in Example 14.2, “JMS configuration bean”, the bean's properties are specified as attributes to the 
bean element. They are all declared in the Spring p namespace.
				Example 14.2. JMS configuration bean
<bean id="jmsConfig"
      class="org.apache.cxf.transport.jms.JMSConfiguration"
      p:connectionFactory="jmsConnectionFactory"
      p:targetDestination="dynamicQueues/greeter.request.queue"
      p:pubSubDomain="false" />
<bean id="jmsConfig"
      class="org.apache.cxf.transport.jms.JMSConfiguration"
      p:connectionFactory="jmsConnectionFactory"
      p:targetDestination="dynamicQueues/greeter.request.queue"
      p:pubSubDomain="false" />Applying the configuration to an endpoint
复制链接链接已复制到粘贴板!
					The 
JMSConfiguration bean can be applied directly to both server and client endpoints using the Apache CXF features mechanism. To do so:
				- Set the endpoint'saddressattribute tojms://.
- Add ajaxws:featureelement to the endpoint's configuration.
- Add a bean of typeorg.apache.cxf.transport.jms.JMSConfigFeatureto the feature.
- Set thebeanelement'sp:jmsConfig-refattribute to the ID of theJMSConfigurationbean.
					Example 14.3, “Adding JMS configuration to a JAX-WS client” shows a JAX-WS client that uses the JMS configuration from Example 14.2, “JMS configuration bean”.
				
Example 14.3. Adding JMS configuration to a JAX-WS client
Applying the configuration to the transport
复制链接链接已复制到粘贴板!
					The 
JMSConfiguration bean can be applied to JMS conduits and JMS destinations using the jms:jmsConfig-ref element. The jms:jmsConfig-ref element's value is the ID of the JMSConfiguration bean.
				
					Example 14.4, “Adding JMS configuration to a JMS conduit” shows a JMS conduit that uses the JMS configuration from Example 14.2, “JMS configuration bean”.
				
Example 14.4. Adding JMS configuration to a JMS conduit
<jms:conduit name="{http://cxf.apache.org/jms_conf_test}HelloWorldQueueBinMsgPort.jms-conduit">
  ...
  <jms:jmsConfig-ref>jmsConf</jms:jmsConfig-ref>
</jms:conduit>
<jms:conduit name="{http://cxf.apache.org/jms_conf_test}HelloWorldQueueBinMsgPort.jms-conduit">
  ...
  <jms:jmsConfig-ref>jmsConf</jms:jmsConfig-ref>
</jms:conduit>