public class DirectBlockingProducer extends DefaultAsyncProducer
DirectEndpoint#isBlock) then the DirectEndpoint will create an instance of this class instead of
DirectProducer. This producers
processmethod will block for the configured duration (
DirectEndpoint#getTimeout, default to 30 seconds). After which if a consumer is still unavailable a DirectConsumerNotAvailableException will be thrown. Implementation note: Concurrent Producers will block for the duration it takes to determine if a consumer is available, but actual consumer execution will happen concurrently.
|Constructor and Description|
|Modifier and Type||Method and Description|
Processes the message exchange
Processes the message exchange.
createExchange, createExchange, createExchange, doStart, doStop, getEndpoint, isSingleton, toString
doResume, doShutdown, doSuspend, getStatus, getVersion, isRunAllowed, isStarted, isStarting, isStopped, isStopping, isStoppingOrStopped, isSuspended, isSuspending, resume, shutdown, start, stop, suspend
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
public boolean process(Exchange exchange, AsyncCallback callback)
Processor.process(org.apache.camel.Exchange), but the caller supports having the exchange asynchronously processed. If there was a failure processing then the caused
Exceptionwould be set on the
exchange- the message exchange
AsyncCallbackwill be invoked when the processing of the exchange is completed. If the exchange is completed synchronously, then the callback is also invoked synchronously. The callback should therefore be careful of starting recursive loop.