Interface ConsistentHashFactory<CH extends ConsistentHash>
- All Known Implementing Classes:
AbstractConsistentHashFactory
,DefaultConsistentHashFactory
,ReplicatedConsistentHashFactory
,SyncConsistentHashFactory
,SyncReplicatedConsistentHashFactory
,TopologyAwareConsistentHashFactory
,TopologyAwareSyncConsistentHashFactory
ConsistentHash
instances.
We say a consistent hash ch
is balanced iif rebalance(ch).equals(ch)
.
The consistent hashes created by create(int, int, List, Map)
must be balanced,
but the ones created by updateMembers(ConsistentHash, List, Map)
and
union(ConsistentHash, ConsistentHash)
will likely be unbalanced.
- Since:
- 5.2
- Author:
- Dan Berindei
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionCreate a new consistent hash instance.default PersistedConsistentHash
<CH> fromPersistentState
(ScopedPersistentState state, Function<UUID, Address> addressMapper) Recreates aConsistentHash
from a previously stored persistent state.Create a new consistent hash instance, based on an existing instance, but balanced according to the implementation's rules.Creates a union of two compatible ConsistentHashes (use the same hashing function and have the same configuration parameters).Updates an existing consistent hash instance to remove owners that are not in thenewMembers
list.
-
Method Details
-
create
CH create(int numOwners, int numSegments, List<Address> members, Map<Address, Float> capacityFactors) Create 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. Ifnull
, all the members are assumed to have a capacity factor of 1.
-
updateMembers
Updates an existing consistent hash instance to remove owners that are not in thenewMembers
list.If a segment has at least one owner in
newMembers
, this method will not add another owner. This guarantees that the new consistent hash can be used immediately, without transferring any state.If a segment has no owners in
newMembers
and theConsistentHash
implementation (e.g.DefaultConsistentHash
) requires at least one owner for each segment, this method may add one or more owners for that segment. Since the data in that segment was lost, the new consistent hash can still be used without transferring state.- Parameters:
baseCH
- An existing consistent hash instance, should not benull
newMembers
- 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. Ifnull
, all the members are assumed to have a capacity factor of 1.- Returns:
- A new
ConsistentHash
instance, orbaseCH
if the existing instance does not need any changes.
-
rebalance
Create 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 benull
- Returns:
- A new
ConsistentHash
instance, orbaseCH
if the existing instance does not need any changes.
-
union
Creates a union of two compatible ConsistentHashes (use the same hashing function and have the same configuration parameters).The owners of a segment
s
inunion(ch1, ch2)
will include both the owners ofs
inch1
and the owners ofs
inch2
, so a cache can switch from usingunion(ch1, ch2)
to usingch2
without transferring any state. -
fromPersistentState
default PersistedConsistentHash<CH> fromPersistentState(ScopedPersistentState state, Function<UUID, Address> addressMapper) Recreates aConsistentHash
from a previously stored persistent state.The stored state typically contains a collection of
UUID
s representing the members. If a member is not present when reading from the state, itsUUID
must be added to thePersistedConsistentHash.missingUuids()
list. ThePersistedConsistentHash.consistentHash()
may have incomplete ownership when there are missing UUIDs.- Parameters:
state
- the state to restore, containing memberUUID
s.addressMapper
- A function to map theUUID
toAddress
.- Returns:
- A
PersistedConsistentHash
with theConsistentHash
and with the missingUUID
if any.
-