Class ScatteredConsistentHashFactory
java.lang.Object
org.infinispan.distribution.ch.impl.AbstractConsistentHashFactory<ScatteredConsistentHash>
org.infinispan.distribution.ch.impl.ScatteredConsistentHashFactory
- All Implemented Interfaces:
- ConsistentHashFactory<ScatteredConsistentHash>
public class ScatteredConsistentHashFactory
extends AbstractConsistentHashFactory<ScatteredConsistentHash>
Based on 
DefaultConsistentHashFactory.- Since:
- 9.0
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classstatic class
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionCreate a new consistent hash instance.booleanRecreates a ConsistentHash from a previously stored persistent state.inthashCode()rebalance(ScatteredConsistentHash baseCH) Create a new consistent hash instance, based on an existing instance, but balanced according to the implementation's rules.protected voidprotected voidunion(ScatteredConsistentHash dch1, ScatteredConsistentHash dch2) Merges two consistent hash objects that have the same number of segments, numOwners and hash function.updateMembers(ScatteredConsistentHash baseCH, List<Address> actualMembers, Map<Address, Float> actualCapacityFactors) Leavers are removed and segments without owners are assigned new owners.Methods inherited from class org.infinispan.distribution.ch.impl.AbstractConsistentHashFactorycheckCapacityFactors, findNewPrimaryOwner, findWorstPrimaryOwnerMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.infinispan.distribution.ch.ConsistentHashFactorycreate
- 
Constructor Details- 
ScatteredConsistentHashFactorypublic ScatteredConsistentHashFactory()
 
- 
- 
Method Details- 
createpublic ScatteredConsistentHash create(int numOwners, int numSegments, List<Address> members, Map<Address, Float> capacityFactors) Description copied from interface:ConsistentHashFactoryCreate a new consistent hash instance. The consistent hash will be balanced.- Parameters:
- numOwners- The ideal number of owners for each key. The created consistent hash can have more or less owners, but each key will have at least one owner.
- numSegments- Number of hash-space segments. The implementation may round up the number of segments for performance, or may ignore the parameter altogether.
- members- A list of addresses representing the new cache members.
- capacityFactors- The capacity factor of each member. Determines the relative capacity of each node compared to the others. The implementation may ignore this parameter. If- null, all the members are assumed to have a capacity factor of 1.
 
- 
fromPersistentStateDescription copied from interface:ConsistentHashFactoryRecreates a ConsistentHash from a previously stored persistent state. The returned ConsistentHash will not have proper addresses, butPersistentUUIDs instead so they will need to be replaced- Parameters:
- state- the state to restore
 
- 
updateMemberspublic ScatteredConsistentHash updateMembers(ScatteredConsistentHash baseCH, List<Address> actualMembers, Map<Address, Float> actualCapacityFactors) Leavers are removed and segments without owners are assigned new owners. Joiners might get some of the un-owned segments but otherwise they are not taken into account (that should happen during a rebalance).- Parameters:
- baseCH- An existing consistent hash instance, should not be- null
- actualMembers- A list of addresses representing the new cache members.
- actualCapacityFactors- The capacity factor of each member. Determines the relative capacity of each node compared to the others. The implementation may ignore this parameter. If- null, all the members are assumed to have a capacity factor of 1.
- Returns:
 
- 
rebalanceDescription copied from interface:ConsistentHashFactoryCreate a new consistent hash instance, based on an existing instance, but balanced according to the implementation's rules.- Parameters:
- baseCH- An existing consistent hash instance, should not be- null
- Returns:
- A new ConsistentHashinstance, orbaseCHif the existing instance does not need any changes.
 
- 
unionMerges two consistent hash objects that have the same number of segments, numOwners and hash function. For each segment, the primary owner of the first CH has priority, the other primary owners become backups.
- 
rebalanceBuilder
- 
replacePrimaryOwners
- 
equals
- 
hashCodepublic int hashCode()
 
-