Package org.frankframework.senders
Class ParallelSenders
java.lang.Object
org.frankframework.senders.AbstractSender
org.frankframework.senders.AbstractSenderWithParameters
org.frankframework.senders.AbstractSenderWrapper
org.frankframework.senders.SenderSeries
org.frankframework.senders.ParallelSenders
- All Implemented Interfaces:
ICacheEnabled<String,
,String> FrankElement
,HasApplicationContext
,HasName
,IConfigurable
,IScopeProvider
,ISender
,ISenderWithParameters
,IWithParameters
,NameAware
,org.springframework.beans.factory.Aware
,org.springframework.context.ApplicationContextAware
,org.springframework.context.Lifecycle
- Direct Known Subclasses:
ShadowSender
Collection of Senders, that are executed all at the same time.
- Since:
- 4.9
- Author:
- Gerrit van Brakel
-
Field Summary
Fields inherited from class org.frankframework.senders.AbstractSenderWrapper
configurationMetrics, senderWrapperProcessor
Fields inherited from class org.frankframework.senders.AbstractSenderWithParameters
parameterNamesMustBeUnique, paramList
Fields inherited from class org.frankframework.senders.AbstractSender
log
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
one or more specifications of senders.void
configure()
is called once at startup of the framework in the configure method of the owner of this sender.protected org.springframework.core.task.TaskExecutor
doSendMessage
(Message message, PipeLineSession session) org.springframework.core.task.TaskExecutor
int
void
setMaxConcurrentThreads
(int maxThreads) Set the upper limit to the amount of concurrent threads that can be run simultaneously.void
setSynchronous
(boolean value) Methods inherited from class org.frankframework.senders.SenderSeries
consumesSessionVariable, getSenders, getStatisticsKeeper, isSenderConfigured, isSynchronous, setSender, start, stop
Methods inherited from class org.frankframework.senders.AbstractSenderWrapper
getCache, getGetInputFromFixedValue, getGetInputFromSessionKey, getStoreInputInSessionKey, getStoreResultInSessionKey, isPreserveInput, sendMessage, setCache, setConfigurationMetrics, setGetInputFromFixedValue, setGetInputFromSessionKey, setName, setPreserveInput, setSenderWrapperProcessor, setStoreInputInSessionKey, setStoreResultInSessionKey
Methods inherited from class org.frankframework.senders.AbstractSenderWithParameters
addParameter, checkStringAttributeOrParameter, getParameterList, getParameterOverriddenAttributeValue, getParameterOverriddenAttributeValue, getParameterValueList
Methods inherited from class org.frankframework.senders.AbstractSender
createBean, getApplicationContext, getConfigurationClassLoader, getLogPrefix, getName, isRunning, setApplicationContext
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.springframework.context.ApplicationContextAware
setApplicationContext
Methods inherited from interface org.frankframework.core.HasApplicationContext
getApplicationContext, getConfigurationClassLoader
Methods inherited from interface org.frankframework.core.ISender
sendMessageOrThrow
-
Constructor Details
-
ParallelSenders
public ParallelSenders()
-
-
Method Details
-
configure
Description copied from interface:ISender
configure()
is called once at startup of the framework in the configure method of the owner of this sender. Purpose of this method is to check whether the static configuration of the sender is correct. As much as possible class-instantiating should take place in theconfigure()
oropen()
method, to improve performance.- Specified by:
configure
in interfaceIConfigurable
- Specified by:
configure
in interfaceISender
- Overrides:
configure
in classSenderSeries
- Throws:
ConfigurationException
- in case it was not able to configure the component.
-
doSendMessage
- Overrides:
doSendMessage
in classSenderSeries
- Throws:
SenderException
-
setSynchronous
public void setSynchronous(boolean value) - Overrides:
setSynchronous
in classSenderSeries
-
createTaskExecutor
protected org.springframework.core.task.TaskExecutor createTaskExecutor() -
addSender
one or more specifications of senders. Each will receive the same input message, to be processed in parallel- Overrides:
addSender
in classSenderSeries
-
setMaxConcurrentThreads
public void setMaxConcurrentThreads(int maxThreads) Set the upper limit to the amount of concurrent threads that can be run simultaneously. Use 0 to disable.- Default value
- 0
-
getMaxConcurrentThreads
public int getMaxConcurrentThreads() -
getExecutor
public org.springframework.core.task.TaskExecutor getExecutor()
-