All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.distribution.group.PartitionerConsistentHash Maven / Gradle / Ivy

There is a newer version: 9.1.7.Final
Show newest version
package org.infinispan.distribution.group;

import java.util.List;
import java.util.Objects;
import java.util.Set;
import java.util.function.UnaryOperator;

import org.infinispan.commons.hash.Hash;
import org.infinispan.distribution.ch.ConsistentHash;
import org.infinispan.distribution.ch.KeyPartitioner;
import org.infinispan.globalstate.ScopedPersistentState;
import org.infinispan.remoting.transport.Address;

/**
 * {@link ConsistentHash} wrapper that uses a {@link KeyPartitioner} instead of a {@link Hash}.
 *
 * @author Dan Berindei
 * @since 8.2
 * @private
 */
public class PartitionerConsistentHash implements ConsistentHash {
   private final ConsistentHash ch;
   private final KeyPartitioner keyPartitioner;

   public PartitionerConsistentHash(ConsistentHash ch, KeyPartitioner keyPartitioner) {
      this.ch = Objects.requireNonNull(ch);
      this.keyPartitioner = Objects.requireNonNull(keyPartitioner);
   }

   @Override
   public int getNumSegments() {
      return ch.getNumSegments();
   }

   @Override
   public int getNumOwners() {
      return ch.getNumOwners();
   }

   @Override
   public List
getMembers() { return ch.getMembers(); } @Override public int getSegment(Object key) { return keyPartitioner.getSegment(key); } @Override public List
locateOwnersForSegment(int segmentId) { return ch.locateOwnersForSegment(segmentId); } @Override public Address locatePrimaryOwnerForSegment(int segmentId) { return ch.locatePrimaryOwnerForSegment(segmentId); } @Override public boolean isSegmentLocalToNode(Address nodeAddress, int segmentId) { return ch.isSegmentLocalToNode(nodeAddress, segmentId); } @Override public boolean isReplicated() { return ch.isReplicated(); } @Override public Set getSegmentsForOwner(Address owner) { return ch.getSegmentsForOwner(owner); } @Override public Set getPrimarySegmentsForOwner(Address owner) { return ch.getPrimarySegmentsForOwner(owner); } @Override public String getRoutingTableAsString() { return ch.getRoutingTableAsString(); } @Override public boolean isKeyLocalToNode(Address nodeAddress, Object key) { int segment = ch.isReplicated() ? 0 : getSegment(key); return ch.isSegmentLocalToNode(nodeAddress, segment); } @Override public Hash getHashFunction() { return ch.getHashFunction(); } public KeyPartitioner getKeyPartitioner() { return keyPartitioner; } @Override public void toScopedState(ScopedPersistentState state) { ch.toScopedState(state); } @Override public ConsistentHash remapAddresses(UnaryOperator
remapper) { return ch.remapAddresses(remapper); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; PartitionerConsistentHash that = (PartitionerConsistentHash) o; if (!ch.equals(that.ch)) return false; return keyPartitioner.equals(that.keyPartitioner); } @Override public int hashCode() { int result = ch.hashCode(); result = 31 * result + keyPartitioner.hashCode(); return result; } @Override public String toString() { return "PartitionerConsistentHash:" + ch; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy