Class RetryTopicComponentFactory
java.lang.Object
org.springframework.kafka.retrytopic.RetryTopicComponentFactory
Provide the component instances that will be used with
 
RetryTopicConfigurationSupport. Override any of the methods to provide
 a different implementation or subclass, then override the
 RetryTopicConfigurationSupport.createComponentFactory() method
 to return this factory's subclass.- Since:
- 2.9
- Author:
- Tomaz Fernandes
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected ClockCreate aClockinstance that will be used for all time-related operations in the retry topic processes.deadLetterPublishingRecovererFactory(DestinationTopicResolver destinationTopicResolver) Create theDeadLetterPublishingRecovererFactorythat will be used to create theDeadLetterPublishingRecovererto forward the records to a givenDestinationTopic.destinationTopicProcessor(DestinationTopicResolver destinationTopicResolver) Create theDestinationTopicProcessorthat will be used to process theDestinationTopicinstances and store them in the providedDestinationTopicResolver.Create the instance ofDestinationTopicResolverthat will be used to store theDestinationTopicinstance and resolve which a given record should be forwarded to.Return theClockinstance that will be used for all time-related operations in the retry topic processes.kafkaBackOffManagerFactory(ListenerContainerRegistry registry, ApplicationContext applicationContext) Create theKafkaBackOffManagerFactorythat will be used to create theKafkaConsumerBackoffManagerinstance used to back off the partitions.listenerContainerFactoryConfigurer(KafkaConsumerBackoffManager kafkaConsumerBackoffManager, DeadLetterPublishingRecovererFactory deadLetterPublishingRecovererFactory, Clock clock) Create aListenerContainerFactoryConfigurerthat will be used to configure theKafkaListenerContainerFactoryresolved by theListenerContainerFactoryResolver.listenerContainerFactoryResolver(BeanFactory beanFactory) Create theListenerContainerFactoryResolverthat will be used to resolve the appropriateKafkaListenerContainerFactoryfor a given topic.retryTopicConfigurer(DestinationTopicProcessor destinationTopicProcessor, ListenerContainerFactoryConfigurer listenerContainerFactoryConfigurer, ListenerContainerFactoryResolver factoryResolver, RetryTopicNamesProviderFactory retryTopicNamesProviderFactory) Create theRetryTopicConfigurerthat will serve as an entry point for configuring non-blocking topic-based delayed retries for a givenKafkaListenerEndpoint, by processing the appropriateRetryTopicConfiguration.Create theRetryTopicNamesProviderFactoryinstance that will be used to provide the property names for the retry topics'KafkaListenerEndpoint.
- 
Constructor Details- 
RetryTopicComponentFactorypublic RetryTopicComponentFactory()
 
- 
- 
Method Details- 
retryTopicConfigurerpublic RetryTopicConfigurer retryTopicConfigurer(DestinationTopicProcessor destinationTopicProcessor, ListenerContainerFactoryConfigurer listenerContainerFactoryConfigurer, ListenerContainerFactoryResolver factoryResolver, RetryTopicNamesProviderFactory retryTopicNamesProviderFactory) Create theRetryTopicConfigurerthat will serve as an entry point for configuring non-blocking topic-based delayed retries for a givenKafkaListenerEndpoint, by processing the appropriateRetryTopicConfiguration.- Parameters:
- destinationTopicProcessor- the- DestinationTopicProcessorthat will be used to process the- DestinationTopicinstances and register them in a- DestinationTopicContainer.
- listenerContainerFactoryConfigurer- the- ListenerContainerFactoryConfigurerthat will be used to configure the- KafkaListenerContainerFactoryinstances for the non-blocking delayed retries feature.
- factoryResolver- the- ListenerContainerFactoryResolverthat will be used to resolve the proper- KafkaListenerContainerFactoryfor a given endpoint or its retry topics.
- retryTopicNamesProviderFactory- the- RetryTopicNamesProviderFactorythat will be used to provide the property names for the retry topics' endpoints.
- Returns:
- the instance.
 
- 
destinationTopicProcessorpublic DestinationTopicProcessor destinationTopicProcessor(DestinationTopicResolver destinationTopicResolver) Create theDestinationTopicProcessorthat will be used to process theDestinationTopicinstances and store them in the providedDestinationTopicResolver.- Parameters:
- destinationTopicResolver- the- DestinationTopicResolverinstance to be used to store the- DestinationTopicinstances.
- Returns:
- the instance.
 
- 
destinationTopicResolverCreate the instance ofDestinationTopicResolverthat will be used to store theDestinationTopicinstance and resolve which a given record should be forwarded to.- Returns:
- the instance.
 
- 
deadLetterPublishingRecovererFactorypublic DeadLetterPublishingRecovererFactory deadLetterPublishingRecovererFactory(DestinationTopicResolver destinationTopicResolver) Create theDeadLetterPublishingRecovererFactorythat will be used to create theDeadLetterPublishingRecovererto forward the records to a givenDestinationTopic.- Parameters:
- destinationTopicResolver- the- DestinationTopicResolverinstance to resolve the destinations.
- Returns:
- the instance.
 
- 
listenerContainerFactoryResolverCreate theListenerContainerFactoryResolverthat will be used to resolve the appropriateKafkaListenerContainerFactoryfor a given topic.- Parameters:
- beanFactory- the- BeanFactorythat will be used to retrieve the- KafkaListenerContainerFactoryinstance if necessary.
- Returns:
- the instance.
 
- 
listenerContainerFactoryConfigurerpublic ListenerContainerFactoryConfigurer listenerContainerFactoryConfigurer(KafkaConsumerBackoffManager kafkaConsumerBackoffManager, DeadLetterPublishingRecovererFactory deadLetterPublishingRecovererFactory, Clock clock) Create aListenerContainerFactoryConfigurerthat will be used to configure theKafkaListenerContainerFactoryresolved by theListenerContainerFactoryResolver.- Parameters:
- kafkaConsumerBackoffManager- the- KafkaConsumerBackoffManagerused with the- KafkaBackoffAwareMessageListenerAdapter.
- deadLetterPublishingRecovererFactory- the factory that will provide the- DeadLetterPublishingRecovererinstance to be used.
- clock- the- Clockinstance to be used with the listener adapter.
- Returns:
- the instance.
 
- 
retryTopicNamesProviderFactoryCreate theRetryTopicNamesProviderFactoryinstance that will be used to provide the property names for the retry topics'KafkaListenerEndpoint.- Returns:
- the instance.
 
- 
kafkaBackOffManagerFactorypublic KafkaBackOffManagerFactory kafkaBackOffManagerFactory(ListenerContainerRegistry registry, ApplicationContext applicationContext) Create theKafkaBackOffManagerFactorythat will be used to create theKafkaConsumerBackoffManagerinstance used to back off the partitions.- Parameters:
- registry- the- ListenerContainerRegistryused to fetch the- MessageListenerContainer.
- applicationContext- the application context.
- Returns:
- the instance.
 
- 
internalRetryTopicClockReturn theClockinstance that will be used for all time-related operations in the retry topic processes.- Returns:
- the instance.
 
- 
createInternalRetryTopicClockCreate aClockinstance that will be used for all time-related operations in the retry topic processes.- Returns:
- the instance.
 
 
-