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.Ce contenu n'est pas disponible dans la langue sélectionnée.
16.3. Configuring How Responses are Received
Overview
Copier lienLien copié sur presse-papiers!
					If your provider endpoint participates in in/out message exchanges, it will wait for a response from receiving endpoint. You can configure the JMS destination on which the endpoint listens for the response. You can also configure the amount of time the endpoint will wait for a response before it times out.
				
Configuring the response destination
Copier lienLien copié sur presse-papiers!
					An endpoint chooses the destination to use for receiving responses with the following algorithm:
				
- If you provided a customDestinationChooserimplementation, the endpoint will use that to choose it's endpoint.For more information about providing customDestinationChooserimplementations see Section 19.1, “Using a Custom Destination Chooser”.
- If you did not provide a customDestinationChooserimplementation, the endpoint will use its defaultDestinationChooserimplementation to choose an endpoint.The default destination chooser checks the message exchange received from the NMR for a DESTINATION_KEY property. If the message exchange has that property set, it returns that destination.
- If the destination chooser does not return a destination, the endpoint will check to see if you configured the destination explicitly.You configure a response destination using a Spring bean. The recommend way to configure the destination is to configure the bean separately and refer the bean using the endpoint'sreplyDestinationattribute as shown in Example 16.1, “Configuring a Provider's Destination”. You can also add the bean directly to the endpoint by wrapping it in ajms:replyDestinationchild element.
- If the destination chooser does not return a destination and you did not explicitly configure a destination, the endpoint will use the value of thereplyDestinationNameattribute to choose its destination.ThereplyDestinationNameattribute takes a string that is used as the name of the destination to use. The binding component's default behavior when you provide a destination name is to resolve the destination using the standard JMSSession.createTopic()andSession.createTopic()methods to resolve the JMS destination.NoteYou can override the binding component's default behavior by providing a customDestinationResolverimplementation. See Section 19.2, “Using a Custom Destination Resolver”.
Configuring the timeout interval
Copier lienLien copié sur presse-papiers!
					By default, a provider endpoint will wait an unlimited amount of time for a response. Since the provider blocks while it is waiting for a response, your application may hang indefinitely if a response does not arrive.
				
					You can configure the endpoint to timeout using the 
recieveTimeout attribute. The recieveTimeout attribute specifies the number of milliseconds the provider endpoint will wait for a response before timing out.
				Example
Copier lienLien copié sur presse-papiers!
					Example 16.4, “JMS Provider Endpoint with a Response Destination” shows a JMS provider endpoint that will wait for a response for one minute.
				
Example 16.4. JMS Provider Endpoint with a Response Destination