SimpleScheduledRoutePolicy
SimpleScheduledRoutePolicy is a ScheduledRoutePolicy
that facilitates route activation, de-activation, suspension and resumption of routes
based on the Quartz simple trigger.
How it works
In order to use a SimpleScheduledRoutePolicy it is necessary to
instantiate an object of the type
org.apache.camel.routepolicy.quartz.SimpleScheduledRoutePolicy.
| All Scheduled route policies share the scheduler created by the Quartz component. In this way, scheduler, jobs and triggers can be managed in a common and consistent way. | 
Configuration options
In order to perform a route operation at a given time the following information must be provided.
- 
Starting a route 
| Parameter Name | Type | Default | Description | 
|---|---|---|---|
| routeStartDate | java.util.Date | the initial scheduled Date and time for route start | |
| routeStartRepeatCount | int | no of times to repeat the job | |
| routeStartRepeatInterval | long | the time interval in milliseconds to trigger the next attempt to start the route | 
- 
Stopping a route 
| Parameter Name | Type | Default | Description | 
|---|---|---|---|
| routeStopDate | java.util.Date | the initial scheduled Date and time for route stop | |
| routeStopRepeatCount | int | no of times to repeat the job | |
| routeStopRepeatInterval | long | the time interval in milliseconds to trigger the next attempt to stop the route | |
| routeStopGracePeriod | int | 10 seconds | the time period to wait before initiating graceful route stop | 
| routeStopTimeUnit | long | TimeUnit.MILLISECONDS | the time unit for the grace period expressed as java.util.concurrent.TimeUnit | 
- 
Suspending a route 
| Parameter Name | Type | Default | Description | 
|---|---|---|---|
| routeSuspendDate | java.util.Date | the initial scheduled Date and time for route suspension | |
| routeSuspendRepeatCount | int | no of times to repeat the job | |
| routeSuspendRepeatInterval | long | the time interval in milliseconds to trigger the next attempt to suspend the route | 
- 
Resuming a route 
| Parameter Name | Type | Default | Description | 
|---|---|---|---|
| routeResumeDate | java.util.Date | the initial scheduled Date and time for route start | |
| routeResumeRepeatCount | int | no of times to repeat the job | |
| routeResumeRepeatInterval | long | the time interval in milliseconds to trigger the next attempt to resume the route | 
Once the
org.apache.camel.routepolicy.quartz.SimpleScheduledRoutePolicy is
created it can be wired into the camel route as follows.
Using the SimpleScheduledRoutePolicy
The SimpleScheduledRoutePolicy can be used in Java DSL as show:
SimpleScheduledRoutePolicy policy = new SimpleScheduledRoutePolicy();
long startTime = System.currentTimeMillis() + 3000L;
policy.setRouteStartDate(new Date(startTime));
policy.setRouteStartRepeatCount(1);
policy.setRouteStartRepeatInterval(3000);
from("direct:start")
   .routeId("test")
   .routePolicy(policy)
   .to("mock:success");And in Spring XML:
<bean id="date" class="org.apache.camel.routepolicy.quartz.SimpleDate"/>
<bean id="startPolicy" class="org.apache.camel.routepolicy.quartz.SimpleScheduledRoutePolicy">
    <property name="routeStartDate" ref="date"/>
    <property name="routeStartRepeatCount" value="1"/>
    <property name="routeStartRepeatInterval" value="3000"/>
</bean>
<camelContext xmlns="http://camel.apache.org/schema/spring">
    <route id="myroute" routePolicyRef="startPolicy">
        <from uri="direct:start"/>
        <to uri="mock:success"/>
    </route>
</camelContext>