Package org.infinispan.scattered
Interface BiasManager
- All Known Implementing Classes:
- BiasManagerImpl
public interface BiasManager
This component tracks if this node can read the data stored locally despite not being an owner
 and which nodes will read the local data that is primary-owned by this node.
 Since tracking these remote nodes has a memory overhead this component can deliberately
 revoke the bias sending the 
RevokeBiasCommand.- 
Nested Class SummaryNested Classes
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddLocalBias(Object key, int topologyId) Allow reading local data if the topology is still actual.voidclear()The cache has been cleared and therefore all biases are forgotten.getRemoteBias(Object key) booleanhasLocalBias(Object key) Check if we can read local data and update last-read timestamp for this key.voidrenewRemoteBias(Object key, Address origin) Notify the component that the node is reading the biased entry and the bias should not be revoked unless necessary.voidrevokeLocalBias(Object key) Stop reading local data.voidrevokeLocalBiasForSegments(IntSet segments) Stop reading local data from this segment.startRevokingRemoteBias(Object key, Address newBiased) Check if there are any nodes that have local bias, and starting replacing them with the provided address.
- 
Method Details- 
addLocalBiasAllow reading local data if the topology is still actual.- Parameters:
- key-
- topologyId-
 
- 
revokeLocalBiasStop reading local data.- Parameters:
- key-
 
- 
revokeLocalBiasForSegmentsStop reading local data from this segment.- Parameters:
- segments-
 
- 
hasLocalBiasCheck if we can read local data and update last-read timestamp for this key.- Parameters:
- key-
- Returns:
 
- 
getRemoteBias
- 
startRevokingRemoteBiasCheck if there are any nodes that have local bias, and starting replacing them with the provided address. The caller can find out the currently biased nodes fromBiasManager.Revocation.biased()and is expected to sendRevokeBiasCommandto the holders and when this completes callBiasManager.Revocation.complete()orBiasManager.Revocation.fail(). This method returnsnullwhen there is no need to revoke any bias on remote nodes. WhenBiasManager.Revocation.shouldRevoke()returns false, the caller should set up a handler throughBiasManager.Revocation.handleCompose(Supplier)and retry calling this method in the handler.- Parameters:
- key-
- newBiased-
- Returns:
 
- 
renewRemoteBiasNotify the component that the node is reading the biased entry and the bias should not be revoked unless necessary.- Parameters:
- key-
- origin-
 
- 
clearvoid clear()The cache has been cleared and therefore all biases are forgotten.
 
-