Class MulticasterBatchListener<T,S>
- java.lang.Object
- org.springframework.batch.core.listener.MulticasterBatchListener<T,S>
- All Implemented Interfaces:
javax.batch.api.chunk.listener.RetryProcessListener
,javax.batch.api.chunk.listener.RetryReadListener
,javax.batch.api.chunk.listener.RetryWriteListener
,ChunkListener
,ItemProcessListener<T,S>
,ItemReadListener<T>
,ItemWriteListener<S>
,SkipListener<T,S>
,StepExecutionListener
,StepListener
public class MulticasterBatchListener<T,S> extends java.lang.Object implements StepExecutionListener, ChunkListener, ItemReadListener<T>, ItemProcessListener<T,S>, ItemWriteListener<S>, SkipListener<T,S>, javax.batch.api.chunk.listener.RetryReadListener, javax.batch.api.chunk.listener.RetryProcessListener, javax.batch.api.chunk.listener.RetryWriteListener
- Author:
- Dave Syer, Michael Minella, Chris Schaefer, Mahmoud Ben Hassine
Field Summary
Fields inherited from interface org.springframework.batch.core.ChunkListener
ROLLBACK_EXCEPTION_KEY
Constructor Summary
Constructors Constructor Description MulticasterBatchListener()
Initialize the listener instance.
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
afterChunk(ChunkContext context)
Callback after the chunk is executed, outside the transaction.void
afterChunkError(ChunkContext context)
Callback after a chunk has been marked for rollback.void
afterProcess(T item, S result)
Called afterItemProcessor.process(Object)
returns.void
afterRead(T item)
Called afterItemReader.read()
.ExitStatus
afterStep(StepExecution stepExecution)
Give a listener a chance to modify the exit status from a step.void
afterWrite(java.util.List<? extends S> items)
Called afterItemWriter.write(java.util.List)
This will be called before any transaction is committed, and beforeChunkListener.afterChunk(ChunkContext)
void
beforeChunk(ChunkContext context)
Callback before the chunk is executed, but inside the transaction.void
beforeProcess(T item)
Called beforeItemProcessor.process(Object)
.void
beforeRead()
Called beforeItemReader.read()
void
beforeStep(StepExecution stepExecution)
Initialize the state of the listener with theStepExecution
from the current scope.void
beforeWrite(java.util.List<? extends S> items)
Called beforeItemWriter.write(java.util.List)
void
onProcessError(T item, java.lang.Exception ex)
Called if an exception was thrown fromItemProcessor.process(Object)
.void
onReadError(java.lang.Exception ex)
Called if an error occurs while trying to read.void
onRetryProcessException(java.lang.Object item, java.lang.Exception ex)
void
onRetryReadException(java.lang.Exception ex)
void
onRetryWriteException(java.util.List<java.lang.Object> items, java.lang.Exception ex)
void
onSkipInProcess(T item, java.lang.Throwable t)
This item failed on processing with the given exception, and a skip was called for.void
onSkipInRead(java.lang.Throwable t)
Callback for a failure on read that is legal, so is not going to be re-thrown.void
onSkipInWrite(S item, java.lang.Throwable t)
This item failed on write with the given exception, and a skip was called for.void
onWriteError(java.lang.Exception ex, java.util.List<? extends S> items)
Called if an error occurs while trying to write.void
register(StepListener listener)
Register the listener for callbacks on the appropriate interfaces implemented.void
setListeners(java.util.List<? extends StepListener> listeners)
Register each of the objects as listeners.
Method Detail
setListeners
public void setListeners(java.util.List<? extends StepListener> listeners)
Register each of the objects as listeners. Once registered, calls to theMulticasterBatchListener
broadcast to the individual listeners.- Parameters:
listeners
- listener objects of types known to the multicaster.
register
public void register(StepListener listener)
Register the listener for callbacks on the appropriate interfaces implemented. AnyStepListener
can be provided, or anItemStream
. Other types will be ignored.- Parameters:
listener
- theStepListener
instance to be registered.
afterProcess
public void afterProcess(T item, @Nullable S result)
Description copied from interface:ItemProcessListener
Called afterItemProcessor.process(Object)
returns. If the processor returnsnull
, this method will still be called, with a {code null} result, allowing for notification of 'filtered' items.- Specified by:
afterProcess
in interfaceItemProcessListener<T,S>
- Parameters:
item
- to be processedresult
- of processing- See Also:
CompositeItemProcessListener.afterProcess(java.lang.Object, java.lang.Object)
beforeProcess
public void beforeProcess(T item)
Description copied from interface:ItemProcessListener
Called beforeItemProcessor.process(Object)
.- Specified by:
beforeProcess
in interfaceItemProcessListener<T,S>
- Parameters:
item
- to be processed.- See Also:
CompositeItemProcessListener.beforeProcess(java.lang.Object)
onProcessError
public void onProcessError(T item, java.lang.Exception ex)
Description copied from interface:ItemProcessListener
Called if an exception was thrown fromItemProcessor.process(Object)
.- Specified by:
onProcessError
in interfaceItemProcessListener<T,S>
- Parameters:
item
- attempted to be processedex
- - exception thrown during processing.- See Also:
CompositeItemProcessListener.onProcessError(java.lang.Object, java.lang.Exception)
afterStep
public ExitStatus afterStep(StepExecution stepExecution)
Description copied from interface:StepExecutionListener
Give a listener a chance to modify the exit status from a step. The value returned will be combined with the normal exit status usingExitStatus.and(ExitStatus)
. Called after execution of step's processing logic (both successful or failed). Throwing exception in this method has no effect, it will only be logged.- Specified by:
afterStep
in interfaceStepExecutionListener
- Parameters:
stepExecution
-StepExecution
instance.- Returns:
- an
ExitStatus
to combine with the normal value. Returnnull
to leave the old value unchanged. - See Also:
CompositeStepExecutionListener.afterStep(StepExecution)
beforeStep
public void beforeStep(StepExecution stepExecution)
Description copied from interface:StepExecutionListener
Initialize the state of the listener with theStepExecution
from the current scope.- Specified by:
beforeStep
in interfaceStepExecutionListener
- Parameters:
stepExecution
- instance ofStepExecution
.- See Also:
CompositeStepExecutionListener.beforeStep(org.springframework.batch.core.StepExecution)
afterChunk
public void afterChunk(ChunkContext context)
Description copied from interface:ChunkListener
Callback after the chunk is executed, outside the transaction.- Specified by:
afterChunk
in interfaceChunkListener
- Parameters:
context
- The currentChunkContext
- See Also:
CompositeChunkListener.afterChunk(ChunkContext context)
beforeChunk
public void beforeChunk(ChunkContext context)
Description copied from interface:ChunkListener
Callback before the chunk is executed, but inside the transaction.- Specified by:
beforeChunk
in interfaceChunkListener
- Parameters:
context
- The currentChunkContext
- See Also:
CompositeChunkListener.beforeChunk(ChunkContext context)
afterRead
public void afterRead(T item)
Description copied from interface:ItemReadListener
Called afterItemReader.read()
. This method is called only for actual items (ie it is not called when the reader returns null).- Specified by:
afterRead
in interfaceItemReadListener<T>
- Parameters:
item
- returned from read()- See Also:
CompositeItemReadListener.afterRead(java.lang.Object)
beforeRead
public void beforeRead()
Description copied from interface:ItemReadListener
Called beforeItemReader.read()
- Specified by:
beforeRead
in interfaceItemReadListener<T>
- See Also:
CompositeItemReadListener.beforeRead()
onReadError
public void onReadError(java.lang.Exception ex)
Description copied from interface:ItemReadListener
Called if an error occurs while trying to read.- Specified by:
onReadError
in interfaceItemReadListener<T>
- Parameters:
ex
- thrown fromItemWriter
- See Also:
CompositeItemReadListener.onReadError(java.lang.Exception)
afterWrite
public void afterWrite(java.util.List<? extends S> items)
Description copied from interface:ItemWriteListener
Called afterItemWriter.write(java.util.List)
This will be called before any transaction is committed, and beforeChunkListener.afterChunk(ChunkContext)
- Specified by:
afterWrite
in interfaceItemWriteListener<T>
- Parameters:
items
- written items- See Also:
ItemWriteListener.afterWrite(List)
beforeWrite
public void beforeWrite(java.util.List<? extends S> items)
Description copied from interface:ItemWriteListener
Called beforeItemWriter.write(java.util.List)
- Specified by:
beforeWrite
in interfaceItemWriteListener<T>
- Parameters:
items
- to be written- See Also:
ItemWriteListener.beforeWrite(List)
onWriteError
public void onWriteError(java.lang.Exception ex, java.util.List<? extends S> items)
Description copied from interface:ItemWriteListener
Called if an error occurs while trying to write. Will be called inside a transaction, but the transaction will normally be rolled back. There is no way to identify from this callback which of the items (if any) caused the error.- Specified by:
onWriteError
in interfaceItemWriteListener<T>
- Parameters:
ex
- thrown fromItemWriter
items
- attempted to be written.- See Also:
ItemWriteListener.onWriteError(Exception, List)
onSkipInRead
public void onSkipInRead(java.lang.Throwable t)
Description copied from interface:SkipListener
Callback for a failure on read that is legal, so is not going to be re-thrown. In case transaction is rolled back and items are re-read, this callback will occur repeatedly for the same cause. This will only happen if read items are not buffered.- Specified by:
onSkipInRead
in interfaceSkipListener<T,S>
- Parameters:
t
- cause of the failure- See Also:
CompositeSkipListener.onSkipInRead(java.lang.Throwable)
onSkipInWrite
public void onSkipInWrite(S item, java.lang.Throwable t)
Description copied from interface:SkipListener
This item failed on write with the given exception, and a skip was called for.- Specified by:
onSkipInWrite
in interfaceSkipListener<T,S>
- Parameters:
item
- the failed itemt
- the cause of the failure- See Also:
CompositeSkipListener.onSkipInWrite(java.lang.Object, java.lang.Throwable)
onSkipInProcess
public void onSkipInProcess(T item, java.lang.Throwable t)
Description copied from interface:SkipListener
This item failed on processing with the given exception, and a skip was called for.- Specified by:
onSkipInProcess
in interfaceSkipListener<T,S>
- Parameters:
item
- the failed itemt
- the cause of the failure- See Also:
CompositeSkipListener.onSkipInProcess(Object, Throwable)
afterChunkError
public void afterChunkError(ChunkContext context)
Description copied from interface:ChunkListener
Callback after a chunk has been marked for rollback. It is invoked after transaction rollback. While the rollback will have occurred, transactional resources might still be active and accessible. Due to this, data access code within this callback will still "participate" in the original transaction unless it declares that it runs in its own transaction. Hence: Use PROPAGATION_REQUIRES_NEW for any transactional operation that is called from here.- Specified by:
afterChunkError
in interfaceChunkListener
- Parameters:
context
- the chunk context containing the exception that caused the underlying rollback.
onRetryReadException
public void onRetryReadException(java.lang.Exception ex) throws java.lang.Exception
- Specified by:
onRetryReadException
in interfacejavax.batch.api.chunk.listener.RetryReadListener
- Throws:
java.lang.Exception
onRetryProcessException
public void onRetryProcessException(java.lang.Object item, java.lang.Exception ex) throws java.lang.Exception
- Specified by:
onRetryProcessException
in interfacejavax.batch.api.chunk.listener.RetryProcessListener
- Throws:
java.lang.Exception
onRetryWriteException
public void onRetryWriteException(java.util.List<java.lang.Object> items, java.lang.Exception ex) throws java.lang.Exception
- Specified by:
onRetryWriteException
in interfacejavax.batch.api.chunk.listener.RetryWriteListener
- Throws:
java.lang.Exception