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.このコンテンツは選択した言語では利用できません。
Chapter 34. Transport Configuration
Important
					The Java Business Integration components of Red Hat JBoss Fuse are considered deprecated. You should consider migrating any JBI applications to OSGi.
				
34.1. 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 34.1, “Declaring the Spring p-namespace”.
				
Example 34.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.
				
					Table 34.1, “General JMS Configuration Properties” lists properties that are common to both providers and consumers.
				
| Property | Default | Description | 
|---|---|---|
| connectionFactory-ref | Specifies a reference to a bean that defines a JMS ConnectionFactory. | |
| wrapInSingleConnectionFactory | true | Specifies whether to wrap the ConnectionFactorywith a SpringSingleConnectionFactory. Doing so can improve the performance of the JMS transport when the specified connection factory does not pool connections. | 
| reconnectOnException | false | Specifies whether to create a new connection in the case of an exception. This property is only used when wrapping the connection factory with a Spring SingleConnectionFactory. | 
| targetDestination | Specifies the JNDI name or provider specific name of a destination. | |
| replyDestination | Specifies the JMS name of the JMS destinations where replies are sent. This attribute allows you to use a user defined destination for replies. For more details see Section 26.3, “Using a Named Reply Destination”. | |
| destinationResolver | Specifies a reference to a Spring DestinationResolver. This allows you to define how destination names are resolved. By default aDynamicDestinationResolveris used. It resolves destinations using the JMS providers features. If you reference aJndiDestinationResolveryou can resolve the destination names using JNDI. | |
| transactionManager | Specifies a reference to a Spring transaction manager. This allows the service to participate in JTA Transactions. | |
| taskExecutor | Specifies a reference to a Spring TaskExecutor. This is used in listeners to decide how to handle incoming messages. By default the transport uses the SpringSimpleAsyncTaskExecutor. | |
| useJms11 | false | Specifies whether JMS 1.1 features are available. | 
| messageIdEnabled | true | Specifies whether the JMS transport wants the JMS broker to provide message IDs. Setting this to falsecauses the endpoint to call its message producer'ssetDisableMessageID()method with a value oftrue. The JMS broker is then given a hint that it does not need to generate message IDs or add them to the messages from the endpoint. The JMS broker can choose to accept the hint or ignore it. | 
| messageTimestampEnabled | true | Specifies whether the JMS transport wants the JMS broker to provide message time stamps. Setting this to falsecauses the endpoint to call its message producer'ssetDisableMessageTimestamp()method with a value oftrue. The JMS broker is then given a hint that it does not need to generate time stamps or add them to the messages from the endpoint. The JMS broker can choose to accept the hint or ignore it. | 
| cacheLevel | 3 | Specifies the level of caching allowed by the listener. Valid values are 0(CACHE_NONE),1(CACHE_CONNECTION),2(CACHE_SESSION),3(CACHE_CONSUMER),4(CACHE_AUTO). | 
| pubSubNoLocal | false | Specifies whether to receive messages produced from the same connection. | 
| receiveTimeout | 0 | Specifies, in milliseconds, the amount of time to wait for response messages. 0means wait indefinitely. | 
| explicitQosEnabled | false | Specifies whether the QoS settings like priority, persistence, and time to live are explicitly set for each message or if they are allowed to use default values. | 
| deliveryMode | 1 | 
									Specifies if a message is persistent. The two values are:
								 
 | 
| priority | 4 | Specifies the message's priority for the messages. JMS priority values can range from 0 to 9. The lowest priority is 0 and the highest priority is 9. | 
| timeToLive | 0 | Specifies, in milliseconds, the message will be available after it is sent. 0 specifies an infinite time to live. | 
| sessionTransacted | false | Specifies if JMS transactions are used. | 
| concurrentConsumers | 1 | Specifies the minimum number of concurrent consumers created by the listener. | 
| maxConcurrentConsumers | 1 | Specifies the maximum number of concurrent consumers by listener. | 
| messageSelector | Specifies the string value of the selector. For more information on the syntax used to specify message selectors, see the JMS 1.1 specification. | |
| subscriptionDurable | false | Specifies whether the server uses durrable subscriptions. | 
| durableSubscriptionName | Specifies the string used to register the durable subscription. | |
| messageType | text | Specifies how the message data will be packaged as a JMS message. textspecifies that the data will be packaged as aTextMessage.binaryspecifies that the data will be packaged as anByteMessage. | 
| pubSubDomain | false | Specifies whether the target destination is a topic. | 
| jmsProviderTibcoEms | false | Specifies if your JMS provider is Tibco EMS. This causes the principal in the security context to be populated from the JMS_TIBCO_SENDERheader. | 
| useMessageIDAsCorrelationID | false | Specifies whether JMS will use the message ID to correlate messages. If not, the client will set a generated correlation ID. | 
					As shown in Example 34.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 34.2. JMS configuration bean
<bean id="jmsConfig"
      class="org.apache.cxf.transport.jms.JMSConfiguration"
      p:connectionFactory-ref="connectionFactory"
      p:targetDestination="dynamicQueues/greeter.request.queue"
      p:pubSubDomain="false" />
<bean id="jmsConfig"
      class="org.apache.cxf.transport.jms.JMSConfiguration"
      p:connectionFactory-ref="connectionFactory"
      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 34.3, “Adding JMS configuration to a JAX-WS client” shows a JAX-WS client that uses the JMS configuration from Example 34.2, “JMS configuration bean”.
				
Example 34.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 34.4, “Adding JMS configuration to a JMS conduit” shows a JMS conduit that uses the JMS configuration from Example 34.2, “JMS configuration bean”.
				
Example 34.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>