Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Wiki Markup
h2. Direct VM Component

...


*Available as of Camel 2.10

...

*

The *direct-vm:* component provides direct, synchronous invocation of any consumers in the JVM when a producer sends a message exchange.

...


This endpoint can be used to connect existing routes in the same camel context, as well from other camel contexts in the *same* JVM.

...



This component differs from the [Direct] component in that [Direct-VM] supports communication across CamelContext instances - so you can use this mechanism to communicate across web applications (provided that camel-core.jar is on the system/boot classpath).

...



At runtime you can swap in new consumers, by stopping the existing consumer(s) and start new consumers.

...


But at any given time there can be at most only one active consumer for a given endpoint.

...



This component allows also to connect routes deployed in different OSGI Bundles as you can see here after. Even if they are running in different bundles, the camel routes will use

...


the same thread. That autorises to develop applications using Transactions -

...

Image Removed

URI format

Code Block
 Tx.

!camel-direct-vm.png|border=1,width=700px!

h3. URI format

{code}
direct-vm:someName

Where someName can be any string to uniquely identify the endpoint

Samples

In the route below we use the direct component to link the two routes together:

Code Block
javajava
{code}

Where *someName* can be any string to uniquely identify the endpoint

h3. Options
{div:class=confluenceTableSmall}
|| Name || Default Value || Description ||
| {{block}} | {{false}} | *Camel 2.11.1:* If sending a message to a direct endpoint which has no active consumer, then we can tell the producer to block and wait for the consumer to become active. |
| {{timeout}} | {{30000}} | *Camel 2.11.1:* The timeout value to use if block is enabled. |
{div}


h3. Samples
In the route below we use the direct component to link the two routes together:

{code:java}
from("activemq:queue:order.in")
    .to("bean:orderServer?method=validate")
    .to("direct-vm:processOrder");
{code}

And now in another CamelContext, such as another OSGi bundle

...


{code
:java
java
}
from("direct-vm:processOrder")
    .to("bean:orderService?method=process")
    .to("activemq:queue:order.out");
{code}

And the sample using spring DSL:

...


{code
:xml
xml
}
   <route>
     <from uri="activemq:queue:order.in"/>
     <to uri="bean:orderService?method=validate"/>
     <to uri="direct-vm:processOrder"/>
  </route>

  <route>
     <from uri="direct-vm:processOrder"/>
     <to uri="bean:orderService?method=process"/>
     <to uri="activemq:queue:order.out"/>
  </route>    

...

{code}

{include:Endpoint See

...

 Also}
- [Direct]
- [SEDA]
- [VM]