Class AggregatingReplyingKafkaTemplate<K,V,R>  
java.lang.Object
org.springframework.kafka.core.KafkaTemplate<K,V>
 
org.springframework.kafka.requestreply.ReplyingKafkaTemplate<K,V,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:
- EventListener,- Aware,- BeanNameAware,- DisposableBean,- InitializingBean,- SmartInitializingSingleton,- ApplicationContextAware,- ApplicationListener<ContextStoppedEvent>,- Lifecycle,- Phased,- SmartLifecycle,- KafkaOperations<K,,- V> - BatchConsumerAwareMessageListener<K,,- Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, - R>>> - BatchMessageListener<K,,- Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, - R>>> - ConsumerSeekAware,- GenericMessageListener<List<org.apache.kafka.clients.consumer.ConsumerRecord<K,,- Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, - R>>>>> - ReplyingKafkaOperations<K,- V, - Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, - R>>> 
public class AggregatingReplyingKafkaTemplate<K,V,R>  
extends ReplyingKafkaTemplate<K,V,Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K,R>>>
implements BatchConsumerAwareMessageListener<K,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 SummaryNested classes/interfaces inherited from interface org.springframework.kafka.listener.ConsumerSeekAwareConsumerSeekAware.ConsumerSeekCallbackNested classes/interfaces inherited from interface org.springframework.kafka.core.KafkaOperationsKafkaOperations.OperationsCallback<K,V, T>, KafkaOperations.ProducerCallback<K, V, T> 
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a normal release by the release strategy.static final StringPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a timeout.Fields inherited from class org.springframework.kafka.core.KafkaTemplateloggerFields inherited from interface org.springframework.kafka.core.KafkaOperationsDEFAULT_POLL_TIMEOUTFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructorsConstructorDescriptionAggregatingReplyingKafkaTemplate(ProducerFactory<K, V> producerFactory, GenericMessageListenerContainer<K, Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, R>>> replyContainer, BiPredicate<List<org.apache.kafka.clients.consumer.ConsumerRecord<K, R>>, Boolean> releaseStrategy) Construct an instance using the provided parameter arguments.
- 
Method SummaryModifier and TypeMethodDescriptionprotected booleanhandleTimeout(Object correlationId, RequestReplyFuture<K, V, 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(List<org.apache.kafka.clients.consumer.ConsumerRecord<K, 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(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, getCorrelationHeaderName, getDefaultReplyTimeout, getPhase, isAutoStartup, isBinaryCorrelation, isPending, isRunning, logLateArrival, onFirstPoll, onMessage, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, sendAndReceive, setAutoStartup, setBinaryCorrelation, setCorrelationHeaderName, setCorrelationIdStrategy, setDefaultReplyTimeout, setPhase, setReplyErrorChecker, setReplyPartitionHeaderName, setReplyTopicHeaderName, setSharedReplyTopic, setTaskScheduler, start, stop, stop, waitForAssignmentMethods inherited from class org.springframework.kafka.core.KafkaTemplateafterSingletonsInstantiated, closeProducer, clusterId, doSend, execute, executeInTransaction, flush, getDefaultTopic, getKafkaAdmin, getMessageConverter, getMicrometerTagsProvider, getObservationRegistry, getProducerFactory, getProducerFactory, getTheProducer, getTransactionIdPrefix, inTransaction, isAllowNonTransactional, isTransactional, metrics, onApplicationEvent, partitionsFor, receive, receive, send, send, send, send, send, send, sendDefault, sendDefault, sendDefault, sendDefault, sendOffsetsToTransaction, setAllowNonTransactional, setApplicationContext, setBeanName, setCloseTimeout, setConsumerFactory, setDefaultTopic, setKafkaAdmin, setMessageConverter, setMessagingConverter, setMicrometerEnabled, setMicrometerTags, setMicrometerTagsProvider, setObservationConvention, setObservationEnabled, setProducerInterceptor, setProducerListener, setTransactionIdPrefixMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.context.ApplicationListenersupportsAsyncExecutionMethods inherited from interface org.springframework.kafka.listener.BatchConsumerAwareMessageListeneronMessageMethods inherited from interface org.springframework.kafka.listener.BatchMessageListeneronMessage, wantsPollResultMethods inherited from interface org.springframework.kafka.listener.ConsumerSeekAwareonIdleContainer, onPartitionsAssigned, onPartitionsRevoked, registerSeekCallback, unregisterSeekCallbackMethods inherited from interface org.springframework.kafka.listener.GenericMessageListeneronMessage, onMessageMethods inherited from interface org.springframework.kafka.core.KafkaOperationsreceive, receive
- 
Field Details- 
AGGREGATED_RESULTS_TOPICPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a normal release by the release strategy.- See Also:
 
- 
PARTIAL_RESULTS_AFTER_TIMEOUT_TOPICPseudo topic name for the "outer"ConsumerRecordthat has the aggregated results in its value after a timeout.- See Also:
 
 
- 
- 
Constructor Details- 
AggregatingReplyingKafkaTemplatepublic AggregatingReplyingKafkaTemplate(ProducerFactory<K, V> producerFactory, GenericMessageListenerContainer<K, Collection<org.apache.kafka.clients.consumer.ConsumerRecord<K, R>>> replyContainer, BiPredicate<List<org.apache.kafka.clients.consumer.ConsumerRecord<K, R>>, 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 Details- 
setCommitTimeoutSet 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(List<org.apache.kafka.clients.consumer.ConsumerRecord<K, 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(Object correlationId, RequestReplyFuture<K, V, 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, - 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.
 
 
-