Class CommandAckCollector
java.lang.Object
org.infinispan.util.concurrent.CommandAckCollector
An acknowledge collector for Triangle algorithm used in non-transactional caches for write operations.
 
Acknowledges are used between the owners and the originator. They signal the completion of a write operation. The operation can complete successfully or not.
The acknowledges are valid on the same cache topology id. So, each acknowledge is tagged with the command topology id. Acknowledges from previous topology id are discarded.
The acknowledges from the primary owner carry the return value of the operation.
- Since:
- 9.0
- Author:
- Pedro Ruivo
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidAcknowledges aPutMapCommandcompletion in the backup owner.voidcompleteExceptionally(long id, Throwable throwable, int topologyId) Acknowledges an exception during the operation execution.<T> org.infinispan.interceptors.distribution.Collector<T> create(long id, Collection<Address> backupOwners, int topologyId) Creates a collector for a single key write operation.<T> org.infinispan.interceptors.distribution.Collector<T> createSegmentBasedCollector(long id, Map<Address, Collection<Integer>> backups, int topologyId) Creates a collector forPutMapCommand.booleanhasPendingBackupAcks(long id) voidonMembersChange(Collection<Address> members) Notifies a change in member list.voidstart()
- 
Constructor Details- 
CommandAckCollectorpublic CommandAckCollector()
 
- 
- 
Method Details- 
startpublic void start()
- 
createpublic <T> org.infinispan.interceptors.distribution.Collector<T> create(long id, Collection<Address> backupOwners, int topologyId) Creates a collector for a single key write operation.- Parameters:
- id- the id from- CommandInvocationId.
- backupOwners- the backup owners of the key.
- topologyId- the current topology id.
 
- 
createSegmentBasedCollectorpublic <T> org.infinispan.interceptors.distribution.Collector<T> createSegmentBasedCollector(long id, Map<Address, Collection<Integer>> backups, int topologyId) Creates a collector forPutMapCommand.- Parameters:
- id- the id from- CommandInvocationId.getId().
- backups- a map between a backup owner and its segments affected.
- topologyId- the current topology id.
 
- 
backupAckAcknowledges aPutMapCommandcompletion in the backup owner.- Parameters:
- id- the id from- CommandInvocationId.getId().
- from- the backup owner.
- segment- the segments affected and acknowledged.
- topologyId- the topology id.
 
- 
completeExceptionallyAcknowledges an exception during the operation execution.The collector is completed without waiting any further acknowledges. - Parameters:
- id- the id from- CommandInvocationId.getId().
- throwable- the- Throwable.
- topologyId- the topology id.
 
- 
getPendingCommands- Returns:
- the pending ids from CommandInvocationId.getId()(testing purposes only)
 
- 
hasPendingBackupAckspublic boolean hasPendingBackupAcks(long id) - Parameters:
- id- the id from- CommandInvocationId.getId().
- Returns:
- trueif there are acknowledges pending from the backup owners,- falseotherwise. (testing purposes only)
 
- 
onMembersChangeNotifies a change in member list.- Parameters:
- members- the new cluster members.
 
 
-