org.apache.camel.component.direct
Class DirectBlockingProducer

java.lang.Object
  extended by org.apache.camel.support.ServiceSupport
      extended by org.apache.camel.impl.DefaultProducer
          extended by org.apache.camel.impl.DefaultAsyncProducer
              extended by org.apache.camel.component.direct.DirectBlockingProducer
All Implemented Interfaces:
AsyncProcessor, IsSingleton, Processor, Producer, Service, ShutdownableService, StatefulService, SuspendableService

public class DirectBlockingProducer
extends DefaultAsyncProducer

The direct producer.

If blocking is enabled (DirectEndpoint#isBlock) then the DirectEndpoint will create an instance of this class instead of DirectProducer. This producers process method 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.


Field Summary
 
Fields inherited from class org.apache.camel.impl.DefaultProducer
log
 
Fields inherited from class org.apache.camel.support.ServiceSupport
shutdown, shuttingdown, started, starting, stopped, stopping, suspended, suspending
 
Constructor Summary
DirectBlockingProducer(DirectEndpoint endpoint)
           
 
Method Summary
protected  DirectConsumer getConsumer(Exchange exchange)
           
 void process(Exchange exchange)
          Processes the message exchange
 boolean process(Exchange exchange, AsyncCallback callback)
          Processes the message exchange.
 
Methods inherited from class org.apache.camel.impl.DefaultProducer
createExchange, createExchange, createExchange, doStart, doStop, getEndpoint, isSingleton, toString
 
Methods inherited from class org.apache.camel.support.ServiceSupport
doResume, doShutdown, doSuspend, getStatus, getVersion, isRunAllowed, isStarted, isStarting, isStopped, isStopping, isStoppingOrStopped, isSuspended, isSuspending, resume, shutdown, start, stop, suspend
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface org.apache.camel.Service
start, stop
 

Constructor Detail

DirectBlockingProducer

public DirectBlockingProducer(DirectEndpoint endpoint)
Method Detail

process

public void process(Exchange exchange)
             throws Exception
Description copied from interface: Processor
Processes the message exchange

Specified by:
process in interface Processor
Overrides:
process in class DefaultAsyncProducer
Parameters:
exchange - the message exchange
Throws:
Exception - if an internal processing error has occurred.

process

public boolean process(Exchange exchange,
                       AsyncCallback callback)
Description copied from interface: AsyncProcessor
Processes the message exchange. Similar to Processor.process(org.apache.camel.Exchange), but the caller supports having the exchange asynchronously processed.

If there was a failure processing then the caused Exception would be set on the Exchange.

Parameters:
exchange - the message exchange
callback - the AsyncCallback will 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.
Returns:
(doneSync) true to continue execute synchronously, false to continue being executed asynchronously

getConsumer

protected DirectConsumer getConsumer(Exchange exchange)
                              throws Exception
Throws:
Exception


Apache Camel