Skip to content

Commit

Permalink
Fix comparator on null ReplicationCheckpoint
Browse files Browse the repository at this point in the history
Signed-off-by: Suraj Singh <[email protected]>
  • Loading branch information
dreamer-89 committed Aug 9, 2022
1 parent de07dac commit 1f07d13
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -313,8 +313,9 @@ private static ShardStoreInfo shardStoreInfo(NodeGatewayStartedShards nodeShardS
NodeGatewayStartedShards::primary
).reversed();

private static final Comparator<NodeGatewayStartedShards> HIGHEST_REPLICATION_CHECKPOINT_FIRST_COMPARATOR = Comparator.nullsLast(
Comparator.comparing(NodeGatewayStartedShards::replicationCheckpoint)
private static final Comparator<NodeGatewayStartedShards> HIGHEST_REPLICATION_CHECKPOINT_FIRST_COMPARATOR = Comparator.comparing(
NodeGatewayStartedShards::replicationCheckpoint,
Comparator.nullsLast(Comparator.naturalOrder())
);

/**
Expand Down Expand Up @@ -387,9 +388,9 @@ protected static NodeShardsResult buildNodeShardsResult(

/**
* Orders the active shards copies based on below comparators
* 1. No store exception
* 2. Shard copies previously primary shard
* 3. Shard copies with highest replication checkpoint. This comparator is NO-OP for doc rep enabled indices.
* 1. No store exception i.e. shard copy is readable
* 2. Prefer previous primary shard
* 3. Prefer shard copy with the highest replication checkpoint. It is NO-OP for doc rep enabled indices.
*/
final Comparator<NodeGatewayStartedShards> comparator; // allocation preference
if (matchAnyShard) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -272,6 +272,39 @@ public void testPreferReplicaWithNullReplicationCheckpoint() {
assertClusterHealthStatus(allocation, ClusterHealthStatus.YELLOW);
}

/**
* Tests that null ReplicationCheckpoint are ignored
*/
public void testPreferReplicaWithAllNullReplicationCheckpoint() {
String allocId1 = randomAlphaOfLength(10);
String allocId2 = randomAlphaOfLength(10);
String allocId3 = randomAlphaOfLength(10);
final RoutingAllocation allocation = routingAllocationWithOnePrimaryNoReplicas(
yesAllocationDeciders(),
CLUSTER_RECOVERED,
allocId1,
allocId2,
allocId3
);
testAllocator.addData(node1, allocId1, false, null, null);
testAllocator.addData(node2, allocId2, false, null, null);
testAllocator.addData(node3, allocId3, true, null, null);
allocateAllUnassigned(allocation);
assertThat(allocation.routingNodesChanged(), equalTo(true));
assertThat(allocation.routingNodes().unassigned().ignored().isEmpty(), equalTo(true));
assertThat(allocation.routingNodes().shardsWithState(ShardRoutingState.INITIALIZING).size(), equalTo(1));
assertThat(
allocation.routingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).currentNodeId(),
equalTo(node3.getId())
);
// Assert node3's allocation id should be used as it was previous primary
assertThat(
allocation.routingNodes().shardsWithState(ShardRoutingState.INITIALIZING).get(0).allocationId().getId(),
equalTo(allocId3)
);
assertClusterHealthStatus(allocation, ClusterHealthStatus.YELLOW);
}

/**
* Tests that replica with highest segment info version will be selected as target on equal primary terms
*/
Expand Down

0 comments on commit 1f07d13

Please sign in to comment.