Class SimpleBatchingStrategy
java.lang.Object
org.springframework.amqp.rabbit.batch.SimpleBatchingStrategy
- All Implemented Interfaces:
- BatchingStrategy
A simple batching strategy that supports only one exchange/routingKey; includes a batch
 size, a batched message size limit and a timeout. The message properties from the first
 message in the batch is used in the batch message. Each message is preceded by a 4 byte
 length field.
- Since:
- 1.4.1
- Author:
- Gary Russell
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionaddToBatch(String exch, String routKey, Message message) Add a message to the batch and optionally release the batch.booleancanDebatch(MessageProperties properties) Return true if this strategy can decode a batch of messages from a message body.voidDebatch a message that has a header withMessageProperties.SPRING_BATCH_FORMATset toMessageProperties.BATCH_FORMAT_LENGTH_HEADER4.Release batch(es), perhaps due to a timeout.
- 
Constructor Details- 
SimpleBatchingStrategypublic SimpleBatchingStrategy(int batchSize, int bufferLimit, long timeout) - Parameters:
- batchSize- the batch size.
- bufferLimit- the max buffer size; could trigger a short batch. Does not apply to a single message.
- timeout- the batch timeout.
 
 
- 
- 
Method Details- 
addToBatchDescription copied from interface:BatchingStrategyAdd a message to the batch and optionally release the batch.- Specified by:
- addToBatchin interface- BatchingStrategy
- Parameters:
- exch- The exchange.
- routKey- The routing key.
- message- The message.
- Returns:
- The batched message (MessageBatch), or null if not ready to release.
 
- 
nextRelease- Specified by:
- nextReleasein interface- BatchingStrategy
- Returns:
- the date the next scheduled release should run, or null if no data to release.
 
- 
releaseBatchesDescription copied from interface:BatchingStrategyRelease batch(es), perhaps due to a timeout.- Specified by:
- releaseBatchesin interface- BatchingStrategy
- Returns:
- The batched message(s).
 
- 
canDebatchDescription copied from interface:BatchingStrategyReturn true if this strategy can decode a batch of messages from a message body. Returning true means you must overrideBatchingStrategy.deBatch(Message, Consumer).- Specified by:
- canDebatchin interface- BatchingStrategy
- Parameters:
- properties- the message properties.
- Returns:
- true if we can decode the message.
- See Also:
 
- 
deBatchDebatch a message that has a header withMessageProperties.SPRING_BATCH_FORMATset toMessageProperties.BATCH_FORMAT_LENGTH_HEADER4.- Specified by:
- deBatchin interface- BatchingStrategy
- Parameters:
- message- the batched message.
- fragmentConsumer- a consumer for each fragment.
- Since:
- 2.2
- See Also:
 
 
-