Class KafkaTransactionManager<K,V> 
- Type Parameters:
- K- the key type.
- V- the value type.
- All Implemented Interfaces:
- Serializable,- KafkaAwareTransactionManager<K,,- V> - ConfigurableTransactionManager,- PlatformTransactionManager,- TransactionManager
PlatformTransactionManager implementation for a
 single Kafka ProducerFactory. Binds a Kafka producer from the specified
 ProducerFactory to the thread, potentially allowing for one thread-bound producer per
 ProducerFactory.
 This local strategy is an alternative to executing Kafka operations within, and synchronized with, external transactions. This strategy is not able to provide XA transactions, for example in order to share transactions between messaging and database access.
 Application code is required to retrieve the transactional Kafka resources via
 ProducerFactoryUtils.getTransactionalResourceHolder(ProducerFactory, String, java.time.Duration).
 Spring's KafkaTemplate will auto
 detect a thread-bound Producer and automatically participate in it.
 
 The use of DefaultKafkaProducerFactory as a target for this transaction manager is strongly
 recommended. Because it caches producers for reuse.
 
Transaction synchronization is turned off by default, as this manager might be used alongside a datastore-based Spring transaction manager such as the JDBC org.springframework.jdbc.datasource.DataSourceTransactionManager, which has stronger needs for synchronization.
- Author:
- Gary Russell
- See Also:
- 
Nested Class SummaryNested classes/interfaces inherited from class org.springframework.transaction.support.AbstractPlatformTransactionManagerAbstractPlatformTransactionManager.SuspendedResourcesHolder
- 
Field SummaryFields inherited from class org.springframework.transaction.support.AbstractPlatformTransactionManagerlogger, SYNCHRONIZATION_ALWAYS, SYNCHRONIZATION_NEVER, SYNCHRONIZATION_ON_ACTUAL_TRANSACTION
- 
Constructor SummaryConstructorsConstructorDescriptionKafkaTransactionManager(ProducerFactory<K, V> producerFactory) Create a new KafkaTransactionManager, given a ProducerFactory.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voiddoBegin(Object transaction, TransactionDefinition definition) protected voiddoCleanupAfterCompletion(Object transaction) protected voiddoCommit(DefaultTransactionStatus status) protected Objectprotected voidprotected voiddoRollback(DefaultTransactionStatus status) protected voidprotected ObjectGet the producer factory.protected booleanisExistingTransaction(Object transaction) voidsetCloseTimeout(Duration closeTimeout) Set the maximum time to wait when closing a producer; default 5 seconds.voidsetTransactionIdPrefix(String transactionIdPrefix) Set a transaction id prefix to override the prefix in the producer factory.Methods inherited from class org.springframework.transaction.support.AbstractPlatformTransactionManagercommit, determineTimeout, getDefaultTimeout, getTransaction, getTransactionExecutionListeners, getTransactionSynchronization, invokeAfterCompletion, isFailEarlyOnGlobalRollbackOnly, isGlobalRollbackOnParticipationFailure, isNestedTransactionAllowed, isRollbackOnCommitFailure, isValidateExistingTransaction, prepareForCommit, registerAfterCompletionWithExistingTransaction, resume, rollback, setDefaultTimeout, setFailEarlyOnGlobalRollbackOnly, setGlobalRollbackOnParticipationFailure, setNestedTransactionAllowed, setRollbackOnCommitFailure, setTransactionExecutionListeners, setTransactionSynchronization, setTransactionSynchronizationName, setValidateExistingTransaction, shouldCommitOnGlobalRollbackOnly, suspend, triggerBeforeCommit, triggerBeforeCompletion, useSavepointForNestedTransactionMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.transaction.ConfigurableTransactionManageraddListenerMethods inherited from interface org.springframework.transaction.PlatformTransactionManagercommit, getTransaction, rollback
- 
Constructor Details- 
KafkaTransactionManagerCreate a new KafkaTransactionManager, given a ProducerFactory. Transaction synchronization is turned off by default, as this manager might be used alongside a datastore-based Spring transaction manager like DataSourceTransactionManager, which has stronger needs for synchronization. Only one manager is allowed to drive synchronization at any point of time.- Parameters:
- producerFactory- the ProducerFactory to use
 
 
- 
- 
Method Details- 
setTransactionIdPrefixSet a transaction id prefix to override the prefix in the producer factory.- Parameters:
- transactionIdPrefix- the prefix.
- Since:
- 2.3
 
- 
getProducerFactoryGet the producer factory.- Specified by:
- getProducerFactoryin interface- KafkaAwareTransactionManager<K,- V> 
- Returns:
- the producerFactory
 
- 
setCloseTimeoutSet the maximum time to wait when closing a producer; default 5 seconds.- Parameters:
- closeTimeout- the close timeout.
- Since:
- 2.1.14
 
- 
doGetTransaction- Specified by:
- doGetTransactionin class- AbstractPlatformTransactionManager
 
- 
isExistingTransaction- Overrides:
- isExistingTransactionin class- AbstractPlatformTransactionManager
 
- 
doBegin- Specified by:
- doBeginin class- AbstractPlatformTransactionManager
 
- 
doSuspend- Overrides:
- doSuspendin class- AbstractPlatformTransactionManager
 
- 
doResume- Overrides:
- doResumein class- AbstractPlatformTransactionManager
 
- 
doCommit- Specified by:
- doCommitin class- AbstractPlatformTransactionManager
 
- 
doRollback- Specified by:
- doRollbackin class- AbstractPlatformTransactionManager
 
- 
doSetRollbackOnly- Overrides:
- doSetRollbackOnlyin class- AbstractPlatformTransactionManager
 
- 
doCleanupAfterCompletion- Overrides:
- doCleanupAfterCompletionin class- AbstractPlatformTransactionManager
 
 
-