Class DefaultConsistentHash
java.lang.Object
org.infinispan.distribution.ch.impl.AbstractConsistentHash
org.infinispan.distribution.ch.impl.DefaultConsistentHash
- All Implemented Interfaces:
ConsistentHash
Default
ConsistentHash implementation. This object is immutable.
Every segment must have a primary owner.- Since:
- 5.2
- Author:
- Dan Berindei, anistor@redhat.com
-
Nested Class Summary
Nested Classes -
Field Summary
Fields inherited from class org.infinispan.distribution.ch.impl.AbstractConsistentHash
capacityFactors, members, STATE_CAPACITY_FACTOR, STATE_CAPACITY_FACTORS, STATE_NUM_SEGMENTS -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleanintintReturns the segments that this cache member is the primary owner for.Returns a string containing all the segments and their associated addresses.getSegmentsForOwner(Address owner) Returns the segments owned by a cache member.inthashCode()booleanisSegmentLocalToNode(Address nodeAddress, int segmentId) Check if a segment is local to a given member.locateOwnersForSegment(int segmentId) locatePrimaryOwnerForSegment(int segmentId) remapAddresses(UnaryOperator<Address> remapper) Returns a new ConsistentHash with the addresses remapped according to the providedUnaryOperator.remapAddressRemoveMissing(UnaryOperator<Address> remapper) Same asConsistentHash.remapAddresses(UnaryOperator)but skip missing members.voidWrites this ConsistentHash to the specified scoped state.toString()union(DefaultConsistentHash dch2) Merges two consistent hash objects that have the same number of segments, numOwners and hash function.Methods inherited from class org.infinispan.distribution.ch.impl.AbstractConsistentHash
checkSameHashAndSegments, getCapacityFactors, getMembers, mergeLists, parseCapacityFactors, parseHashFunction, parseMembers, parseNumSegments, remapCapacityFactors, remapMembers, unionCapacityFactorsMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.infinispan.distribution.ch.ConsistentHash
isReplicated
-
Constructor Details
-
DefaultConsistentHash
-
-
Method Details
-
getNumSegments
public int getNumSegments()- Returns:
- The actual number of hash space segments. Note that it may not be the same as the number of segments passed in at creation time.
-
getSegmentsForOwner
Description copied from interface:ConsistentHashReturns the segments owned by a cache member.- Parameters:
owner- the address of the member- Returns:
- a non-null set of segment IDs, may or may not be unmodifiable, which shouldn't be modified by caller.
The set is empty if
owneris not a member of the consistent hash.
-
getPrimarySegmentsForOwner
Description copied from interface:ConsistentHashReturns the segments that this cache member is the primary owner for.- Parameters:
owner- the address of the member- Returns:
- a non-null set of segment IDs, may or may not be unmodifiable, which shouldn't be modified by caller.
The set is empty if
owneris not a member of the consistent hash.
-
locateOwnersForSegment
- Returns:
- All the nodes that own a given hash space segment, first address is the primary owner. The returned list is unmodifiable.
-
locatePrimaryOwnerForSegment
- Returns:
- The primary owner of a given hash space segment. This is equivalent to
locateOwnersForSegment(segmentId).get(0)but is more efficient
-
getNumOwners
public int getNumOwners() -
isSegmentLocalToNode
Description copied from interface:ConsistentHashCheck if a segment is local to a given member.Implementation note: normally key-based method are implemented based on segment-based methods. Here, however, we need a default implementation for the segment-based method for backwards-compatibility reasons.
-
hashCode
public int hashCode() -
equals
-
toString
-
getRoutingTableAsString
Description copied from interface:ConsistentHashReturns a string containing all the segments and their associated addresses. -
union
Merges 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. -
prettyPrintOwnership
-
toScopedState
Description copied from interface:ConsistentHashWrites this ConsistentHash to the specified scoped state. Before invoking this method, the ConsistentHash addresses will have to be replaced with their correspondingPersistentUUIDs- Specified by:
toScopedStatein interfaceConsistentHash- Overrides:
toScopedStatein classAbstractConsistentHash- Parameters:
state- the state to which this ConsistentHash will be written
-
remapAddresses
Description copied from interface:ConsistentHashReturns a new ConsistentHash with the addresses remapped according to the providedUnaryOperator. If an address cannot me remapped (i.e. the remapper returns null) this method should return null.- Parameters:
remapper- the remapper which given an address replaces it with another one- Returns:
- the remapped ConsistentHash or null if one of the remapped addresses is null
-
remapAddressRemoveMissing
Description copied from interface:ConsistentHashSame asConsistentHash.remapAddresses(UnaryOperator)but skip missing members.- Parameters:
remapper- : the remapper which given an address replaces it with another one- Returns:
- the remapped ConsistentHash
-