Class AggregatingReplyingKafkaTemplate<K,V,R>
- java.lang.Object
- 
- org.springframework.kafka.core.KafkaTemplate<K,V>
- 
- org.springframework.kafka.requestreply.ReplyingKafkaTemplate<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>
- 
- org.springframework.kafka.requestreply.AggregatingReplyingKafkaTemplate<K,V,R>
 
 
 
- 
- Type Parameters:
- K- the key type.
- V- the outbound data type.
- R- the reply data type.
 - All Implemented Interfaces:
- java.util.EventListener,- org.springframework.beans.factory.Aware,- org.springframework.beans.factory.BeanNameAware,- org.springframework.beans.factory.DisposableBean,- org.springframework.beans.factory.InitializingBean,- org.springframework.context.ApplicationContextAware,- org.springframework.context.ApplicationListener<org.springframework.context.event.ContextStoppedEvent>,- org.springframework.context.Lifecycle,- org.springframework.context.Phased,- org.springframework.context.SmartLifecycle,- KafkaOperations<K,V>,- BatchConsumerAwareMessageListener<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>,- BatchMessageListener<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>,- GenericMessageListener<java.util.List<org.apache.kafka.clients.consumer.ConsumerRecord<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>>>,- ReplyingKafkaOperations<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>
 
 public class AggregatingReplyingKafkaTemplate<K,V,R> extends ReplyingKafkaTemplate<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> implements BatchConsumerAwareMessageListener<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> A replying template that aggregates multiple replies with the same correlation id.- Since:
- 2.3
- Author:
- Gary Russell
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.springframework.kafka.core.KafkaOperationsKafkaOperations.OperationsCallback<K,V,T>, KafkaOperations.ProducerCallback<K,V,T>
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static java.lang.StringAGGREGATED_RESULTS_TOPICPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a normal release by the release strategy.static java.lang.StringPARTIAL_RESULTS_AFTER_TIMEOUT_TOPICPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a timeout.- 
Fields inherited from class org.springframework.kafka.core.KafkaTemplatelogger
 - 
Fields inherited from interface org.springframework.kafka.core.KafkaOperationsDEFAULT_POLL_TIMEOUT
 
- 
 - 
Constructor SummaryConstructors Constructor Description AggregatingReplyingKafkaTemplate(ProducerFactory<K,V> producerFactory, GenericMessageListenerContainer<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> replyContainer, java.util.function.BiPredicate<java.util.List<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>,java.lang.Boolean> releaseStrategy)Construct an instance using the provided parameter arguments.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected booleanhandleTimeout(CorrelationKey correlationId, RequestReplyFuture<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> future)Used to inform subclasses that a request has timed out so they can clean up state and, optionally, complete the future.voidonMessage(java.util.List<org.apache.kafka.clients.consumer.ConsumerRecord<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>> data, org.apache.kafka.clients.consumer.Consumer<?,?> consumer)Invoked with data from kafka and provides access to theConsumer.voidsetCommitTimeout(java.time.Duration commitTimeout)Set the timeout to use when committing offsets.voidsetReturnPartialOnTimeout(boolean returnPartialOnTimeout)Set to true to return a partial result when a request times out.- 
Methods inherited from class org.springframework.kafka.requestreply.ReplyingKafkaTemplateafterPropertiesSet, checkDeserialization, checkForErrors, destroy, getAssignedReplyTopicPartitions, getDefaultReplyTimeout, getPhase, isAutoStartup, isPending, isRunning, logLateArrival, onMessage, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, setAutoStartup, setCorrelationHeaderName, setCorrelationIdStrategy, setDefaultReplyTimeout, setPhase, setReplyErrorChecker, setReplyPartitionHeaderName, setReplyTopicHeaderName, setSharedReplyTopic, setTaskScheduler, start, stop, stop
 - 
Methods inherited from class org.springframework.kafka.core.KafkaTemplatecloseProducer, doSend, execute, executeInTransaction, flush, getDefaultTopic, getMessageConverter, getProducerFactory, getProducerFactory, getTheProducer, getTransactionIdPrefix, inTransaction, isAllowNonTransactional, isTransactional, metrics, onApplicationEvent, partitionsFor, receive, receive, send, send, send, send, send, send, sendDefault, sendDefault, sendDefault, sendDefault, sendOffsetsToTransaction, sendOffsetsToTransaction, sendOffsetsToTransaction, setAllowNonTransactional, setApplicationContext, setBeanName, setCloseTimeout, setConsumerFactory, setDefaultTopic, setMessageConverter, setMessagingConverter, setMicrometerEnabled, setMicrometerTags, setProducerListener, setTransactionIdPrefix
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.springframework.kafka.listener.BatchConsumerAwareMessageListeneronMessage
 - 
Methods inherited from interface org.springframework.kafka.listener.BatchMessageListeneronMessage, wantsPollResult
 - 
Methods inherited from interface org.springframework.kafka.listener.GenericMessageListeneronMessage, onMessage
 - 
Methods inherited from interface org.springframework.kafka.core.KafkaOperationsreceive, receive
 
- 
 
- 
- 
- 
Field Detail- 
AGGREGATED_RESULTS_TOPICpublic static final java.lang.String AGGREGATED_RESULTS_TOPIC Pseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a normal release by the release strategy.- See Also:
- Constant Field Values
 
 - 
PARTIAL_RESULTS_AFTER_TIMEOUT_TOPICpublic static final java.lang.String PARTIAL_RESULTS_AFTER_TIMEOUT_TOPIC Pseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a timeout.- See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
AggregatingReplyingKafkaTemplatepublic AggregatingReplyingKafkaTemplate(ProducerFactory<K,V> producerFactory, GenericMessageListenerContainer<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> replyContainer, java.util.function.BiPredicate<java.util.List<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>,java.lang.Boolean> releaseStrategy) Construct an instance using the provided parameter arguments. The releaseStrategy is consulted to determine when a collection is "complete".- Parameters:
- producerFactory- the producer factory.
- replyContainer- the reply container.
- releaseStrategy- the release strategy which is a- BiPredicatewhich is passed the current list and a boolean to indicate if this is for a normal delivery or a timeout (when- setReturnPartialOnTimeout(boolean)is true. The predicate may modify the list of records.
- Since:
- 2.3.5
 
 
- 
 - 
Method Detail- 
setCommitTimeoutpublic void setCommitTimeout(java.time.Duration commitTimeout) Set the timeout to use when committing offsets.- Parameters:
- commitTimeout- the timeout.
 
 - 
setReturnPartialOnTimeoutpublic void setReturnPartialOnTimeout(boolean returnPartialOnTimeout) Set to true to return a partial result when a request times out.- Parameters:
- returnPartialOnTimeout- true to return a partial result.
 
 - 
onMessagepublic void onMessage(java.util.List<org.apache.kafka.clients.consumer.ConsumerRecord<K,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>> data, org.apache.kafka.clients.consumer.Consumer<?,?> consumer) Description copied from interface:GenericMessageListenerInvoked with data from kafka and provides access to theConsumer. The default implementation throwsUnsupportedOperationException.- Specified by:
- onMessagein interface- BatchConsumerAwareMessageListener<K,V>
- Specified by:
- onMessagein interface- GenericMessageListener<K>
- Parameters:
- data- the data to be processed.
- consumer- the consumer.
 
 - 
handleTimeoutprotected boolean handleTimeout(CorrelationKey correlationId, RequestReplyFuture<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>> future) Description copied from class:ReplyingKafkaTemplateUsed to inform subclasses that a request has timed out so they can clean up state and, optionally, complete the future.- Overrides:
- handleTimeoutin class- ReplyingKafkaTemplate<K,V,java.util.Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>
- Parameters:
- correlationId- the correlation id.
- future- the future.
- Returns:
- true to indicate the future has been completed.
 
 
- 
 
-