Skip to content

Commit

Permalink
Caching number of primary shards per node for evaluating constraints …
Browse files Browse the repository at this point in the history
…on avg primary shards across all indices per node (opensearch-project#14992)

Signed-off-by: RS146BIJAY <[email protected]>
  • Loading branch information
RS146BIJAY authored and harshavamsi committed Aug 20, 2024
1 parent 1fa8dba commit 1db8132
Showing 1 changed file with 11 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -476,6 +476,7 @@ void updateRebalanceConstraint(String constraint, boolean add) {
public static class ModelNode implements Iterable<ModelIndex> {
private final Map<String, ModelIndex> indices = new HashMap<>();
private int numShards = 0;
private int numPrimaryShards = 0;
private final RoutingNode routingNode;

ModelNode(RoutingNode routingNode) {
Expand Down Expand Up @@ -509,7 +510,7 @@ public int numPrimaryShards(String idx) {
}

public int numPrimaryShards() {
return indices.values().stream().mapToInt(index -> index.numPrimaryShards()).sum();
return numPrimaryShards;
}

public int highestPrimary(String index) {
Expand All @@ -527,6 +528,10 @@ public void addShard(ShardRouting shard) {
indices.put(index.getIndexId(), index);
}
index.addShard(shard);
if (shard.primary()) {
numPrimaryShards++;
}

numShards++;
}

Expand All @@ -538,6 +543,11 @@ public void removeShard(ShardRouting shard) {
indices.remove(shard.getIndexName());
}
}

if (shard.primary()) {
numPrimaryShards--;
}

numShards--;
}

Expand Down

0 comments on commit 1db8132

Please sign in to comment.