org.infinispan.distribution.ch.impl.OwnershipStatistics Maven / Gradle / Ivy
package org.infinispan.distribution.ch.impl;
import org.infinispan.distribution.ch.ConsistentHash;
import org.infinispan.remoting.transport.Address;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* This class holds statistics about a consistent hash. It counts how many segments are owned or primary-owned by each
* member.
*
* @author Dan Berindei
* @since 5.2
*/
public class OwnershipStatistics {
private final Map nodes;
private final int[] primaryOwned;
private final int[] owned;
public OwnershipStatistics(List nodes) {
this.nodes = new HashMap(nodes.size());
for (int i = 0; i < nodes.size(); i++) {
this.nodes.put(nodes.get(i), i);
}
this.primaryOwned = new int[nodes.size()];
this.owned = new int[nodes.size()];
}
public OwnershipStatistics(ConsistentHash ch, List activeNodes) {
this(activeNodes);
for (int i = 0; i < ch.getNumSegments(); i++) {
List owners = ch.locateOwnersForSegment(i);
for (int j = 0; j < owners.size(); j++) {
Address address = owners.get(j);
Integer nodeIndex = nodes.get(address);
if (nodeIndex != null) {
if (j == 0) {
primaryOwned[nodeIndex]++;
}
owned[nodeIndex]++;
}
}
}
}
public OwnershipStatistics(OwnershipStatistics other) {
this.nodes = new HashMap(other.nodes);
this.primaryOwned = Arrays.copyOf(other.primaryOwned, other.primaryOwned.length);
this.owned = Arrays.copyOf(other.owned, other.owned.length);
}
public int getPrimaryOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
return 0;
return primaryOwned[i];
}
public int getOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
return 0;
return owned[i];
}
public void incPrimaryOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
throw new IllegalArgumentException("Trying to modify statistics for a node that doesn't exist: " + a);
primaryOwned[i]++;
}
public void incOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
throw new IllegalArgumentException("Trying to modify statistics for a node that doesn't exist: " + a);
owned[i]++;
}
public void decPrimaryOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
throw new IllegalArgumentException("Trying to modify statistics for a node that doesn't exist: " + a);
primaryOwned[i]--;
}
public void decOwned(Address a) {
Integer i = nodes.get(a);
if (i == null)
throw new IllegalArgumentException("Trying to modify statistics for a node that doesn't exist: " + a);
owned[i]--;
}
public int sumPrimaryOwned() {
int segmentsWithPrimaryOwners = 0;
for (int ownedCount : primaryOwned) {
segmentsWithPrimaryOwners += ownedCount;
}
return segmentsWithPrimaryOwners;
}
public int sumOwned() {
int allOwnersCount = 0;
for (int ownedCount : owned) {
allOwnersCount += ownedCount;
}
return allOwnersCount;
}
public String toString() {
StringBuilder sb = new StringBuilder("OwnershipStatistics{");
boolean isFirst = true;
for (Map.Entry e : nodes.entrySet()) {
if (!isFirst) {
sb.append(", ");
}
Address node = e.getKey();
Integer index = e.getValue();
sb.append(node).append(": ").append(primaryOwned[index]).append('+').append(owned[index] - primaryOwned[index]);
isFirst = false;
}
return sb.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy