|
Page Edited :
CAMEL :
Error Handler
Error Handler has been edited by Claus Ibsen (Nov 20, 2008). Change summary: CAMEL-1105: RedeliveryPolicy now supports ref Error HandlerCamel supports pluggable ErrorHandler Some current implementations include
These error handlers can be applied in the DSL to an entire set of rules or a specific routing rule as we show in the next examples. Error handling rules are inherited on each routing rule within a single RouteBuilder Short Summary of the provided Error HandlersDefault Error Handler (Dead Letter Channel)The default error handler is the Dead Letter Channel which is automatically configured for you. By default Camel will redeliver at most 6 times using 1 second delay, and if the exchange failed it will be logged at ERROR level. You can configure the default dead letter endpoint to use: RouteBuilder builder = new RouteBuilder() { public void configure() { errorHandler(deadLetterChannel("seda:errors")); from("seda:a").to("seda:b"); } };
The error handler is configured with the errorHandlerRef attribute.
Spring based configuration sampleIn this sample we configure a Dead Letter Channel on the route that should redeliver at most 3 times and use a little delay before retrying. <camelContext id="camel" xmlns="http://activemq.apache.org/camel/schema/spring"> <template id="myTemplate"/> <!-- set the errorHandlerRef to our DeadLetterChannel, this applies for this route only --> <route errorHandlerRef="myDeadLetterErrorHandler"> <from uri="direct:in"/> <process ref="myFailureProcessor"/> <to uri="mock:result"/> </route> </camelContext> Then we configure myDeadLetterErrorHandler that is our Dead Letter Channel. This configuration is standard Spring using the bean element. <!-- here we configure our DeadLetterChannel --> <bean id="myDeadLetterErrorHandler" class="org.apache.camel.builder.DeadLetterChannelBuilder"> <!-- exchanges is routed to mock:dead in cased redelivery failed --> <property name="defaultDeadLetterEndpointUri" value="mock:dead"/> <!-- reference the redelivery policy to use --> <property name="redeliveryPolicy" ref="myRedeliveryPolicyConfig"/> </bean> <!-- here we set the redelivery settings --> <bean id="myRedeliveryPolicyConfig" class="org.apache.camel.processor.RedeliveryPolicy"> <!-- try redelivery at most 3 times, after that the exchange is dead and its routed to the mock:dead endpoint --> <property name="maximumRedeliveries" value="3"/> <!-- delay 250ms before redelivery --> <property name="delay" value="250"/> </bean> Redelivery PolicyYou can also configure the RedeliveryPolicy RouteBuilder builder = new RouteBuilder() { public void configure() { errorHandler(deadLetterChannel("seda:errors").maximumRedeliveries(2).useExponentialBackOff()); from("seda:a").to("seda:b"); } }; And configuration of the redelivery policy in Spring DSL is as: <onException> <exception>java.io.IOException</exception> <redeliveryPolicy delay="1000" maximumRedeliveries="3" maximumRedeliveryDelay="10000" backOffMultiplier="1.0" useExponentialBackOff="true" retryAttemptedLogLevel="TRACE" retriesExhaustedLogLevel="FATAL" /> <setHeader headerName="messageInfo"> <constant>Damm somekind of IO exception</constant> </setHeader> <to uri="mock:error"/> </onException> Available as of Camel 1.5.1 or later <bean id="myRedeliveryPolicy" class="org.apache.camel.processor.RedeliveryPolicy"> <property name="maximumRedeliveries" value="${myprop.max}"/> </bean> <onException> <!-- you can define multiple exceptions just adding more exception elements as show below --> <exception>com.mycompany.MyFirstException</exception> <exception>com.mycompany.MySecondException</exception> <!-- here we reference our redelivy policy defined above --> <redeliveryPolicy ref="myRedeliveryPolicy"/> </onException> Exception Policy StrategyAs of Camel 1.4 you can configure the ExceptionPolicyStrategy public void configure() throws Exception { // configure the error handler to use my policy instead of the default from Camel errorHandler(deadLetterChannel().exceptionPolicyStrategy(new MyPolicy())); onException(MyPolicyException.class) .maximumRedeliveries(1) .setHeader(MESSAGE_INFO, constant("Damm my policy exception")) .to(ERROR_QUEUE); onException(CamelException.class) .maximumRedeliveries(3) .setHeader(MESSAGE_INFO, constant("Damm a Camel exception")) .to(ERROR_QUEUE); Using our own strategy MyPolicy we can change the default behavior of Camel with our own code to resolve which ExceptionType public static class MyPolicy implements ExceptionPolicyStrategy { public ExceptionType getExceptionPolicy(Map<Class, ExceptionType> exceptionPolicices, Exchange exchange, Throwable exception) { // This is just an example that always forces the exception type configured // with MyPolicyException to win. return exceptionPolicices.get(MyPolicyException.class); } } Using the transactional error handlerThe transactional error handler is introduced in Camel 1.4 and is based on spring transaction. This requires the usage of the camel-spring component. See alsoThe Dead Letter Channel for further details. |
Unsubscribe or edit your notifications preferences
