Package org.apache.camel.model
Class RoutingSlipDefinition<Type extends ProcessorDefinition<Type>>
- java.lang.Object
-
- org.apache.camel.model.OptionalIdentifiedDefinition<Type>
-
- org.apache.camel.model.ProcessorDefinition<ExpressionNode>
-
- org.apache.camel.model.ExpressionNode
-
- org.apache.camel.model.RoutingSlipDefinition<Type>
-
- All Implemented Interfaces:
org.apache.camel.CamelContextAware
,org.apache.camel.LineNumberAware
,Block
,HasExpressionType
,org.apache.camel.NamedNode
,org.apache.camel.spi.HasId
,org.apache.camel.spi.IdAware
@Metadata(label="eip,routing") public class RoutingSlipDefinition<Type extends ProcessorDefinition<Type>> extends ExpressionNode
Routes a message through a series of steps that are pre-determined (the slip)
-
-
Field Summary
Fields Modifier and Type Field Description static String
DEFAULT_DELIMITER
-
Fields inherited from class org.apache.camel.model.ProcessorDefinition
disabled, inheritErrorHandler
-
-
Constructor Summary
Constructors Constructor Description RoutingSlipDefinition()
RoutingSlipDefinition(String headerName)
RoutingSlipDefinition(String headerName, String uriDelimiter)
RoutingSlipDefinition(org.apache.camel.Expression expression)
RoutingSlipDefinition(org.apache.camel.Expression expression, String uriDelimiter)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description RoutingSlipDefinition<Type>
cacheSize(int cacheSize)
Sets the maximum size used by theProducerCache
which is used to cache and reuse producers when using this routing slip, when uris are reused.RoutingSlipDefinition<Type>
cacheSize(String cacheSize)
Sets the maximum size used by theProducerCache
which is used to cache and reuse producers when using this routing slip, when uris are reused.Type
end()
Ends the current blockString
getCacheSize()
String
getIgnoreInvalidEndpoints()
String
getLabel()
Returns a label to describe this node such as the expression if some kind of expression nodeList<ProcessorDefinition<?>>
getOutputs()
String
getShortName()
String
getUriDelimiter()
RoutingSlipDefinition<Type>
ignoreInvalidEndpoints()
Ignore the invalidate endpoint exception when try to create a producer with that endpointRoutingSlipDefinition<Type>
ignoreInvalidEndpoints(boolean ignoreInvalidEndpoints)
Ignore the invalidate endpoint exception when try to create a producer with that endpointRoutingSlipDefinition<Type>
ignoreInvalidEndpoints(String ignoreInvalidEndpoints)
Ignore the invalidate endpoint exception when try to create a producer with that endpointvoid
setCacheSize(String cacheSize)
void
setExpression(ExpressionDefinition expression)
Expression to define the routing slip, which defines which endpoints to route the message in a pipeline style.void
setIgnoreInvalidEndpoints(String ignoreInvalidEndpoints)
void
setUriDelimiter(String uriDelimiter)
String
toString()
RoutingSlipDefinition<Type>
uriDelimiter(String uriDelimiter)
Sets the uri delimiter to use-
Methods inherited from class org.apache.camel.model.ExpressionNode
configureChild, getExpression, getExpressionType, id, preCreateProcessor, setExpression, setExpressionType
-
Methods inherited from class org.apache.camel.model.ProcessorDefinition
addInterceptStrategy, addOutput, aggregate, aggregate, aggregate, aggregate, bean, bean, bean, bean, bean, bean, bean, bean, bean, bean, bean, choice, circuitBreaker, claimCheck, claimCheck, claimCheck, claimCheck, clearOutput, convertBodyTo, convertBodyTo, convertBodyTo, delay, delay, delay, disabled, disabled, disabled, doTry, dynamicRouter, dynamicRouter, endChoice, endCircuitBreaker, endDoCatch, endDoTry, endParent, enrich, enrich, enrich, enrich, enrich, enrich, enrich, enrich, enrich, enrichWith, enrichWith, enrichWith, enrichWith, enrichWith, enrichWith, filter, filter, filter, filter, getDisabled, getIndex, getInterceptStrategies, getParent, getRouteConfiguration, idempotentConsumer, idempotentConsumer, idempotentConsumer, inheritErrorHandler, inOnly, inOnly, inOnly, inOnly, inOnly, inOut, inOut, inOut, inOut, inOut, isAbstract, isInheritErrorHandler, isTopLevelOnly, isWrappingEntireOutput, kamelet, loadBalance, loadBalance, log, log, log, log, log, log, loop, loop, loop, loopDoWhile, loopDoWhile, markRollbackOnly, markRollbackOnlyLast, marshal, marshal, marshal, marshal, multicast, multicast, multicast, nodePrefixId, onCompletion, onException, onException, pausable, pausable, pausable, pausable, pipeline, pipeline, pipeline, pipeline, policy, policy, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrich, pollEnrichWith, pollEnrichWith, pollEnrichWith, pollEnrichWith, pollEnrichWith, pollEnrichWith, process, process, process, recipientList, recipientList, recipientList, recipientList, removeHeader, removeHeaders, removeHeaders, removeProperties, removeProperties, removeProperty, resequence, resequence, resumable, resumable, resumable, rollback, rollback, routeDescription, routeGroup, routeId, routingSlip, routingSlip, routingSlip, saga, sample, sample, sample, sample, sample, script, script, serviceCall, serviceCall, serviceCall, setBody, setBody, setBody, setDisabled, setExchangePattern, setExchangePattern, setHeader, setHeader, setHeader, setInheritErrorHandler, setParent, setProperty, setProperty, setProperty, setRouteConfiguration, sort, sort, sort, split, split, split, split, startupOrder, step, step, stop, threads, threads, threads, threads, throttle, throttle, throttle, throttle, throttle, throwException, throwException, to, to, to, to, to, to, to, to, to, to, to, to, to, to, toD, toD, toD, toD, toD, toD, toD, toF, transacted, transacted, transform, transform, unmarshal, unmarshal, unmarshal, unmarshal, unmarshal, unmarshal, unmarshal, validate, validate, validate, wireTap, wireTap, wireTap
-
Methods inherited from class org.apache.camel.model.OptionalIdentifiedDefinition
description, description, getCamelContext, getCustomId, getDescription, getDescriptionText, getId, getLineNumber, getLocation, hasCustomIdAssigned, idOrCreate, setCamelContext, setCustomId, setDescription, setGeneratedId, setId, setLineNumber, setLocation
-
-
-
-
Field Detail
-
DEFAULT_DELIMITER
public static final String DEFAULT_DELIMITER
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
RoutingSlipDefinition
public RoutingSlipDefinition()
-
RoutingSlipDefinition
public RoutingSlipDefinition(String headerName)
-
RoutingSlipDefinition
public RoutingSlipDefinition(org.apache.camel.Expression expression, String uriDelimiter)
-
RoutingSlipDefinition
public RoutingSlipDefinition(org.apache.camel.Expression expression)
-
-
Method Detail
-
getShortName
public String getShortName()
-
getLabel
public String getLabel()
Description copied from class:ProcessorDefinition
Returns a label to describe this node such as the expression if some kind of expression node- Specified by:
getLabel
in interfaceorg.apache.camel.NamedNode
- Overrides:
getLabel
in classExpressionNode
-
getOutputs
public List<ProcessorDefinition<?>> getOutputs()
- Overrides:
getOutputs
in classExpressionNode
-
setExpression
public void setExpression(ExpressionDefinition expression)
Expression to define the routing slip, which defines which endpoints to route the message in a pipeline style. Notice the expression is evaluated once, if you want a more dynamic style, then the dynamic router eip is a better choice.- Overrides:
setExpression
in classExpressionNode
-
setUriDelimiter
public void setUriDelimiter(String uriDelimiter)
-
getUriDelimiter
public String getUriDelimiter()
-
setIgnoreInvalidEndpoints
public void setIgnoreInvalidEndpoints(String ignoreInvalidEndpoints)
-
getIgnoreInvalidEndpoints
public String getIgnoreInvalidEndpoints()
-
getCacheSize
public String getCacheSize()
-
setCacheSize
public void setCacheSize(String cacheSize)
-
end
public Type end()
Description copied from class:ProcessorDefinition
Ends the current block- Overrides:
end
in classProcessorDefinition<ExpressionNode>
- Returns:
- the builder
-
ignoreInvalidEndpoints
public RoutingSlipDefinition<Type> ignoreInvalidEndpoints()
Ignore the invalidate endpoint exception when try to create a producer with that endpoint- Returns:
- the builder
-
ignoreInvalidEndpoints
public RoutingSlipDefinition<Type> ignoreInvalidEndpoints(boolean ignoreInvalidEndpoints)
Ignore the invalidate endpoint exception when try to create a producer with that endpoint- Returns:
- the builder
-
ignoreInvalidEndpoints
public RoutingSlipDefinition<Type> ignoreInvalidEndpoints(String ignoreInvalidEndpoints)
Ignore the invalidate endpoint exception when try to create a producer with that endpoint- Returns:
- the builder
-
uriDelimiter
public RoutingSlipDefinition<Type> uriDelimiter(String uriDelimiter)
Sets the uri delimiter to use- Parameters:
uriDelimiter
- the delimiter- Returns:
- the builder
-
cacheSize
public RoutingSlipDefinition<Type> cacheSize(int cacheSize)
Sets the maximum size used by theProducerCache
which is used to cache and reuse producers when using this routing slip, when uris are reused. Beware that when using dynamic endpoints then it affects how well the cache can be utilized. If each dynamic endpoint is unique then its best to turn of caching by setting this to -1, which allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches. However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size (1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help reduce memory usage to avoid storing too many non frequent used producers.- Parameters:
cacheSize
- the cache size, use 0 for default cache size, or -1 to turn cache off.- Returns:
- the builder
-
cacheSize
public RoutingSlipDefinition<Type> cacheSize(String cacheSize)
Sets the maximum size used by theProducerCache
which is used to cache and reuse producers when using this routing slip, when uris are reused. Beware that when using dynamic endpoints then it affects how well the cache can be utilized. If each dynamic endpoint is unique then its best to turn of caching by setting this to -1, which allows Camel to not cache both the producers and endpoints; they are regarded as prototype scoped and will be stopped and discarded after use. This reduces memory usage as otherwise producers/endpoints are stored in memory in the caches. However if there are a high degree of dynamic endpoints that have been used before, then it can benefit to use the cache to reuse both producers and endpoints and therefore the cache size can be set accordingly or rely on the default size (1000). If there is a mix of unique and used before dynamic endpoints, then setting a reasonable cache size can help reduce memory usage to avoid storing too many non frequent used producers.- Parameters:
cacheSize
- the cache size, use 0 for default cache size, or -1 to turn cache off.- Returns:
- the builder
-
-