Package org.infinispan.transaction.impl
Class AbstractCacheTransaction
java.lang.Object
org.infinispan.transaction.impl.AbstractCacheTransaction
- All Implemented Interfaces:
- CacheTransaction
- Direct Known Subclasses:
- LocalTransaction,- RemoteTransaction
Base class for local and remote transaction. Impl note: The aggregated modification list and lookedUpEntries are not
 instantiated here but in subclasses. This is done in order to take advantage of the fact that, for remote
 transactions we already know the size of the modifications list at creation time.
- Since:
- 4.2
- Author:
- Mircea.Markus@jboss.com, Galder ZamarreƱo
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.infinispan.transaction.xa.CacheTransactionCacheTransaction.TransactionCompletedListener
- 
Field SummaryFieldsModifier and TypeFieldDescriptionHolds all the locked keys that were acquired by the transaction allover the cluster.protected Map<Object,CacheEntry> protected ModificationListprotected final intprotected final GlobalTransaction
- 
Constructor SummaryConstructorsConstructorDescriptionAbstractCacheTransaction(GlobalTransaction tx, int topologyId, long txCreationTime) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddAffectedKey(Object key) voidaddAllAffectedKeys(Collection<?> keys) voidfinal voidvoidaddVersionRead(Object key, EntryVersion version) Sets the version read for this key.protected final voidvoidIt cleans up the backup locks for this transaction.voidvoidvoidforEachBackupLock(Consumer<Object> consumer) Invokes theConsumerwith each backup lock.voidforEachLock(Consumer<Object> consumer) Invokes theConsumerwith each lock.voidPrevent new modifications after prepare or commit started.final List<org.infinispan.commands.write.WriteCommand>Returns all the modifications visible within the current transaction, including those using Flag#CACHE_MODE_LOCAL.longReturns the transaction identifier.final List<org.infinispan.commands.write.WriteCommand>Returns the modifications visible within the current transaction.It returns aCompletableFuturethat completes when the lock for thekeyis released.Same asCacheTransaction.getReleaseFutureForKey(Object)but it returns a pair with the key and the future.final FlagintNote: used in Repeatable Read + Write Skew + Clustering + Versioning.final booleanfinal booleanfinal booleanlookupEntry(Object key) voidmarkForRollback(boolean markForRollback) voidbooleanvoidregisterLockedKey(Object key) voidremoveBackupLock(Object key) It cleans up the backup forkey.voidremoveBackupLocks(Collection<?> keys) It cleans up the backup lock for thekeys.voidfinal voidsetModifications(List<org.infinispan.commands.write.WriteCommand> modifications) abstract voidsetStateTransferFlag(Flag stateTransferFlag) voidsetUpdatedEntryVersions(Map<Object, IncrementableEntryVersion> updatedEntryVersions) Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.infinispan.transaction.xa.CacheTransactionhasModification, putLookedUpEntries, putLookedUpEntry
- 
Field Details- 
tx
- 
modifications
- 
lookedUpEntries
- 
affectedKeysHolds all the locked keys that were acquired by the transaction allover the cluster.
- 
topologyIdprotected final int topologyId
 
- 
- 
Constructor Details- 
AbstractCacheTransaction
 
- 
- 
Method Details- 
isMarkedForRollbackpublic final boolean isMarkedForRollback()- Specified by:
- isMarkedForRollbackin interface- CacheTransaction
 
- 
markForRollbackpublic void markForRollback(boolean markForRollback) - Specified by:
- markForRollbackin interface- CacheTransaction
 
- 
getGlobalTransactionDescription copied from interface:CacheTransactionReturns the transaction identifier.- Specified by:
- getGlobalTransactionin interface- CacheTransaction
 
- 
getModificationsDescription copied from interface:CacheTransactionReturns the modifications visible within the current transaction. Any modifications using Flag#CACHE_MODE_LOCAL are excluded. The returned list is never null.- Specified by:
- getModificationsin interface- CacheTransaction
 
- 
getAllModificationsDescription copied from interface:CacheTransactionReturns all the modifications visible within the current transaction, including those using Flag#CACHE_MODE_LOCAL. The returned list is never null.- Specified by:
- getAllModificationsin interface- CacheTransaction
 
- 
setModifications
- 
hasModificationspublic final boolean hasModifications()
- 
freezeModificationspublic void freezeModifications()Description copied from interface:CacheTransactionPrevent new modifications after prepare or commit started.- Specified by:
- freezeModificationsin interface- CacheTransaction
 
- 
getLookedUpEntries- Specified by:
- getLookedUpEntriesin interface- CacheTransaction
 
- 
lookupEntry- Specified by:
- lookupEntryin interface- CacheTransaction
 
- 
removeLookedUpEntry- Specified by:
- removeLookedUpEntryin interface- CacheTransaction
 
- 
clearLookedUpEntriespublic void clearLookedUpEntries()- Specified by:
- clearLookedUpEntriesin interface- CacheTransaction
 
- 
ownsLock- Specified by:
- ownsLockin interface- CacheTransaction
 
- 
notifyOnTransactionFinishedpublic void notifyOnTransactionFinished()- Specified by:
- notifyOnTransactionFinishedin interface- CacheTransaction
- See Also:
- 
- AbstractTxLockingInterceptor.checkPendingAndLockKey(TxInvocationContext, VisitableCommand, Object, long)
 
 
- 
getTopologyIdpublic int getTopologyId()- Specified by:
- getTopologyIdin interface- CacheTransaction
 
- 
addBackupLockForKey- Specified by:
- addBackupLockForKeyin interface- CacheTransaction
 
- 
registerLockedKey
- 
getLockedKeys- Specified by:
- getLockedKeysin interface- CacheTransaction
 
- 
getBackupLockedKeys
- 
clearLockedKeyspublic void clearLockedKeys()- Specified by:
- clearLockedKeysin interface- CacheTransaction
 
- 
getAffectedKeys
- 
addAffectedKey
- 
addAllAffectedKeys
- 
getUpdatedEntryVersions- Specified by:
- getUpdatedEntryVersionsin interface- CacheTransaction
 
- 
setUpdatedEntryVersions- Specified by:
- setUpdatedEntryVersionsin interface- CacheTransaction
 
- 
addVersionReadDescription copied from interface:CacheTransactionSets the version read for this key. The version is only set at the first time, i.e. multiple invocation of this method will not change the state. Note: used in Repeatable Read + Write Skew + Clustering + Versioning.- Specified by:
- addVersionReadin interface- CacheTransaction
 
- 
getVersionsReadDescription copied from interface:CacheTransactionNote: used in Repeatable Read + Write Skew + Clustering + Versioning.- Specified by:
- getVersionsReadin interface- CacheTransaction
- Returns:
- a non-null map between key and version. The map represents the version read for that key. If no version exists, the key has not been read.
 
- 
isFromStateTransferpublic final boolean isFromStateTransfer()
- 
getStateTransferFlag
- 
setStateTransferFlag
- 
getCreationTimepublic long getCreationTime()- Specified by:
- getCreationTimein interface- CacheTransaction
 
- 
addListener- Specified by:
- addListenerin interface- CacheTransaction
 
- 
getReleaseFutureForKeyDescription copied from interface:CacheTransactionIt returns aCompletableFuturethat completes when the lock for thekeyis released. If thekeyis not locked by this transaction, it returnsnull.- Specified by:
- getReleaseFutureForKeyin interface- CacheTransaction
- Parameters:
- key- the key.
- Returns:
- the CompletableFutureornullif the key is not locked by this transaction.
 
- 
getReleaseFutureForKeysDescription copied from interface:CacheTransactionSame asCacheTransaction.getReleaseFutureForKey(Object)but it returns a pair with the key and the future.- Specified by:
- getReleaseFutureForKeysin interface- CacheTransaction
 
- 
cleanupBackupLockspublic void cleanupBackupLocks()Description copied from interface:CacheTransactionIt cleans up the backup locks for this transaction.- Specified by:
- cleanupBackupLocksin interface- CacheTransaction
 
- 
removeBackupLocksDescription copied from interface:CacheTransactionIt cleans up the backup lock for thekeys.- Specified by:
- removeBackupLocksin interface- CacheTransaction
- Parameters:
- keys- The keys to clean up the backup lock.
 
- 
removeBackupLockDescription copied from interface:CacheTransactionIt cleans up the backup forkey.- Specified by:
- removeBackupLockin interface- CacheTransaction
- Parameters:
- key- The key to clean up the backup lock.
 
- 
forEachLockDescription copied from interface:CacheTransactionInvokes theConsumerwith each lock.- Specified by:
- forEachLockin interface- CacheTransaction
- Parameters:
- consumer- The backup lock- Consumer
 
- 
forEachBackupLockDescription copied from interface:CacheTransactionInvokes theConsumerwith each backup lock.- Specified by:
- forEachBackupLockin interface- CacheTransaction
- Parameters:
- consumer- The backup lock- Consumer
 
- 
checkIfRolledBackprotected final void checkIfRolledBack()
 
-