Package org.springframework.kafka.config
Class StreamsBuilderFactoryBean
java.lang.Object
org.springframework.beans.factory.config.AbstractFactoryBean<org.apache.kafka.streams.StreamsBuilder>
org.springframework.kafka.config.StreamsBuilderFactoryBean
- All Implemented Interfaces:
- Aware,- BeanClassLoaderAware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- FactoryBean<org.apache.kafka.streams.StreamsBuilder>,- InitializingBean,- Lifecycle,- Phased,- SmartLifecycle
public class StreamsBuilderFactoryBean
extends AbstractFactoryBean<org.apache.kafka.streams.StreamsBuilder>
implements SmartLifecycle, BeanNameAware
An 
AbstractFactoryBean for the StreamsBuilder instance
 and lifecycle control for the internal KafkaStreams instance.
 
 A fine grained control on KafkaStreams can be achieved by
 KafkaStreamsCustomizers.
- Since:
- 1.1.4
- Author:
- Artem Bilan, Ivan Ursul, Soby Chacko, Zach Olauson, Nurettin Yilmaz, Denis Washington, Gary Russell, Cédric Schaller
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceCalled whenever aKafkaStreamsis added or removed.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final DurationThe defaultDurationof10 secondsfor close timeout.Fields inherited from class org.springframework.beans.factory.config.AbstractFactoryBeanloggerFields inherited from interface org.springframework.beans.factory.FactoryBeanOBJECT_TYPE_ATTRIBUTEFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructorsConstructorDescriptionDefault constructor that creates the factory without configurationProperties.StreamsBuilderFactoryBean(KafkaStreamsConfiguration streamsConfig) Construct an instance with the supplied streams configuration.StreamsBuilderFactoryBean(KafkaStreamsConfiguration streamsConfig, CleanupConfig cleanupConfig) Construct an instance with the supplied streams configuration and clean up configuration.
- 
Method SummaryModifier and TypeMethodDescriptionvoidAdd aStreamsBuilderFactoryBean.Listenerwhich will be called after starting and stopping the streams.protected org.apache.kafka.streams.StreamsBuilderorg.apache.kafka.streams.KafkaStreamsGet a managed by thisStreamsBuilderFactoryBeanKafkaStreamsinstance.Get the current list of listeners.Class<?>intgetPhase()org.apache.kafka.streams.errors.StreamsUncaughtExceptionHandlerRetrieves the currentStreamsUncaughtExceptionHandlerset on this factory bean.org.apache.kafka.streams.TopologyProviding access to the associatedTopologyof thisStreamsBuilderFactoryBean.booleanbooleanbooleanRemove a listener.voidsetAutoStartup(boolean autoStartup) voidsetBeanName(String name) voidsetCleanupConfig(CleanupConfig cleanupConfig) voidsetClientSupplier(org.apache.kafka.streams.KafkaClientSupplier clientSupplier) voidsetCloseTimeout(int closeTimeout) Specify the timeout in seconds for theKafkaStreams.close(Duration)operation.voidsetInfrastructureCustomizer(KafkaStreamsInfrastructureCustomizer infrastructureCustomizer) Set a customizer to configure the builder and/or topology before creating the stream.voidsetKafkaStreamsCustomizer(KafkaStreamsCustomizer kafkaStreamsCustomizer) voidsetPhase(int phase) voidsetStateListener(org.apache.kafka.streams.KafkaStreams.StateListener stateListener) voidsetStateRestoreListener(org.apache.kafka.streams.processor.StateRestoreListener stateRestoreListener) voidsetStreamsConfiguration(Properties streamsConfig) Set the streams configurationPropertieson this factory.voidsetStreamsUncaughtExceptionHandler(org.apache.kafka.streams.errors.StreamsUncaughtExceptionHandler streamsUncaughtExceptionHandler) Set aStreamsUncaughtExceptionHandler.voidstart()voidstop()voidMethods inherited from class org.springframework.beans.factory.config.AbstractFactoryBeanafterPropertiesSet, destroy, destroyInstance, getBeanFactory, getBeanTypeConverter, getEarlySingletonInterfaces, getObject, isSingleton, setBeanClassLoader, setBeanFactory, setSingleton
- 
Field Details- 
DEFAULT_CLOSE_TIMEOUTThe defaultDurationof10 secondsfor close timeout.- See Also:
- 
- KafkaStreams.close(Duration)
 
 
 
- 
- 
Constructor Details- 
StreamsBuilderFactoryBeanpublic StreamsBuilderFactoryBean()Default constructor that creates the factory without configurationProperties. It is the factory user's responsibility to properly setPropertiesusingsetStreamsConfiguration(Properties).- Since:
- 2.1.3.
 
- 
StreamsBuilderFactoryBeanpublic StreamsBuilderFactoryBean(KafkaStreamsConfiguration streamsConfig, CleanupConfig cleanupConfig) Construct an instance with the supplied streams configuration and clean up configuration.- Parameters:
- streamsConfig- the streams configuration.
- cleanupConfig- the cleanup configuration.
- Since:
- 2.2
 
- 
StreamsBuilderFactoryBeanConstruct an instance with the supplied streams configuration.- Parameters:
- streamsConfig- the streams configuration.
- Since:
- 2.2
 
 
- 
- 
Method Details- 
setBeanName- Specified by:
- setBeanNamein interface- BeanNameAware
 
- 
setStreamsConfigurationSet the streams configurationPropertieson this factory.- Parameters:
- streamsConfig- the streams configuration.
- Since:
- 2.2
 
- 
getStreamsConfiguration
- 
setClientSupplierpublic void setClientSupplier(org.apache.kafka.streams.KafkaClientSupplier clientSupplier) 
- 
setInfrastructureCustomizerpublic void setInfrastructureCustomizer(KafkaStreamsInfrastructureCustomizer infrastructureCustomizer) Set a customizer to configure the builder and/or topology before creating the stream.- Parameters:
- infrastructureCustomizer- the customizer
- Since:
- 2.4.1
 
- 
setKafkaStreamsCustomizer- Parameters:
- kafkaStreamsCustomizer- the- KafkaStreamsCustomizerto use.
- Since:
- 2.1.5
 
- 
setStateListenerpublic void setStateListener(org.apache.kafka.streams.KafkaStreams.StateListener stateListener) 
- 
setStreamsUncaughtExceptionHandlerpublic void setStreamsUncaughtExceptionHandler(org.apache.kafka.streams.errors.StreamsUncaughtExceptionHandler streamsUncaughtExceptionHandler) Set aStreamsUncaughtExceptionHandler. Supercedes#setUncaughtExceptionHandler(java.lang.Thread.UncaughtExceptionHandler).- Parameters:
- streamsUncaughtExceptionHandler- the handler.
- Since:
- 2.8
 
- 
getStreamsUncaughtExceptionHandler@Nullable public org.apache.kafka.streams.errors.StreamsUncaughtExceptionHandler getStreamsUncaughtExceptionHandler()Retrieves the currentStreamsUncaughtExceptionHandlerset on this factory bean.- Returns:
- StreamsUncaughtExceptionHandler
- Since:
- 2.8.4
 
- 
setStateRestoreListenerpublic void setStateRestoreListener(org.apache.kafka.streams.processor.StateRestoreListener stateRestoreListener) 
- 
setCloseTimeoutpublic void setCloseTimeout(int closeTimeout) Specify the timeout in seconds for theKafkaStreams.close(Duration)operation. Defaults toDEFAULT_CLOSE_TIMEOUTseconds.- Parameters:
- closeTimeout- the timeout for close in seconds.
- See Also:
- 
- KafkaStreams.close(Duration)
 
 
- 
getTopologyProviding access to the associatedTopologyof thisStreamsBuilderFactoryBean.- Returns:
- Topologyobject
- Since:
- 2.4.4
 
- 
getObjectType- Specified by:
- getObjectTypein interface- FactoryBean<org.apache.kafka.streams.StreamsBuilder>
- Specified by:
- getObjectTypein class- AbstractFactoryBean<org.apache.kafka.streams.StreamsBuilder>
 
- 
setAutoStartuppublic void setAutoStartup(boolean autoStartup) 
- 
setPhasepublic void setPhase(int phase) 
- 
getPhasepublic int getPhase()- Specified by:
- getPhasein interface- Phased
- Specified by:
- getPhasein interface- SmartLifecycle
 
- 
setCleanupConfig
- 
getKafkaStreamsGet a managed by thisStreamsBuilderFactoryBeanKafkaStreamsinstance.- Returns:
- KafkaStreams managed instance;
 may be null if this StreamsBuilderFactoryBeanhasn't been started.
- Since:
- 1.1.4
 
- 
getListenersGet the current list of listeners.- Returns:
- the listeners.
- Since:
- 2.5.3
 
- 
addListenerAdd aStreamsBuilderFactoryBean.Listenerwhich will be called after starting and stopping the streams.- Parameters:
- listener- the listener.
- Since:
- 2.5.3
 
- 
removeListenerRemove a listener.- Parameters:
- listener- the listener.
- Returns:
- true if removed.
- Since:
- 2.5.3
 
- 
createInstanceprotected org.apache.kafka.streams.StreamsBuilder createInstance()- Specified by:
- createInstancein class- AbstractFactoryBean<org.apache.kafka.streams.StreamsBuilder>
 
- 
isAutoStartuppublic boolean isAutoStartup()- Specified by:
- isAutoStartupin interface- SmartLifecycle
 
- 
stop- Specified by:
- stopin interface- SmartLifecycle
 
- 
startpublic void start()
- 
stoppublic void stop()
- 
isRunningpublic boolean isRunning()
 
-