Fix off-by-one error in chunks coordinator (#31147)
This commit fixes an off-by-error in the chunks coordinator where the batches would be of size one more than the batch size.
This commit is contained in:
parent
bf1152fcc6
commit
20a2f646e2
|
@ -234,11 +234,17 @@ public class ShardFollowTasksExecutor extends PersistentTasksExecutor<ShardFollo
|
||||||
this.countDown = new CountDown(concurrentProcessors);
|
this.countDown = new CountDown(concurrentProcessors);
|
||||||
}
|
}
|
||||||
|
|
||||||
void createChucks(long from, long to) {
|
/**
|
||||||
|
* Creates chunks of the specified range, inclusive.
|
||||||
|
*
|
||||||
|
* @param from the lower end of the range (inclusive)
|
||||||
|
* @param to the upper end of the range (inclusive)
|
||||||
|
*/
|
||||||
|
void createChucks(final long from, final long to) {
|
||||||
LOGGER.debug("{} Creating chunks for operation range [{}] to [{}]", leaderShard, from, to);
|
LOGGER.debug("{} Creating chunks for operation range [{}] to [{}]", leaderShard, from, to);
|
||||||
for (long i = from; i < to; i += batchSize) {
|
for (long i = from; i < to; i += batchSize) {
|
||||||
long v2 = i + batchSize < to ? i + batchSize : to;
|
long v2 = i + batchSize <= to ? i + batchSize - 1 : to;
|
||||||
chunks.add(new long[]{i == from ? i : i + 1, v2});
|
chunks.add(new long[]{i, v2});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -58,47 +58,47 @@ public class ChunksCoordinatorTests extends ESTestCase {
|
||||||
followShardId.getIndex(), client, client);
|
followShardId.getIndex(), client, client);
|
||||||
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1024, 1,
|
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1024, 1,
|
||||||
Long.MAX_VALUE, leaderShardId, followShardId, e -> {});
|
Long.MAX_VALUE, leaderShardId, followShardId, e -> {});
|
||||||
coordinator.createChucks(0, 1024);
|
coordinator.createChucks(0, 1023);
|
||||||
List<long[]> result = new ArrayList<>(coordinator.getChunks());
|
List<long[]> result = new ArrayList<>(coordinator.getChunks());
|
||||||
assertThat(result.size(), equalTo(1));
|
assertThat(result.size(), equalTo(1));
|
||||||
assertThat(result.get(0)[0], equalTo(0L));
|
assertThat(result.get(0)[0], equalTo(0L));
|
||||||
assertThat(result.get(0)[1], equalTo(1024L));
|
assertThat(result.get(0)[1], equalTo(1023L));
|
||||||
|
|
||||||
coordinator.getChunks().clear();
|
coordinator.getChunks().clear();
|
||||||
coordinator.createChucks(0, 2048);
|
coordinator.createChucks(0, 2047);
|
||||||
result = new ArrayList<>(coordinator.getChunks());
|
result = new ArrayList<>(coordinator.getChunks());
|
||||||
assertThat(result.size(), equalTo(2));
|
assertThat(result.size(), equalTo(2));
|
||||||
assertThat(result.get(0)[0], equalTo(0L));
|
assertThat(result.get(0)[0], equalTo(0L));
|
||||||
assertThat(result.get(0)[1], equalTo(1024L));
|
assertThat(result.get(0)[1], equalTo(1023L));
|
||||||
assertThat(result.get(1)[0], equalTo(1025L));
|
assertThat(result.get(1)[0], equalTo(1024L));
|
||||||
assertThat(result.get(1)[1], equalTo(2048L));
|
assertThat(result.get(1)[1], equalTo(2047L));
|
||||||
|
|
||||||
coordinator.getChunks().clear();
|
coordinator.getChunks().clear();
|
||||||
coordinator.createChucks(0, 4096);
|
coordinator.createChucks(0, 4095);
|
||||||
result = new ArrayList<>(coordinator.getChunks());
|
result = new ArrayList<>(coordinator.getChunks());
|
||||||
assertThat(result.size(), equalTo(4));
|
assertThat(result.size(), equalTo(4));
|
||||||
assertThat(result.get(0)[0], equalTo(0L));
|
assertThat(result.get(0)[0], equalTo(0L));
|
||||||
assertThat(result.get(0)[1], equalTo(1024L));
|
assertThat(result.get(0)[1], equalTo(1023L));
|
||||||
assertThat(result.get(1)[0], equalTo(1025L));
|
assertThat(result.get(1)[0], equalTo(1024L));
|
||||||
assertThat(result.get(1)[1], equalTo(2048L));
|
assertThat(result.get(1)[1], equalTo(2047L));
|
||||||
assertThat(result.get(2)[0], equalTo(2049L));
|
assertThat(result.get(2)[0], equalTo(2048L));
|
||||||
assertThat(result.get(2)[1], equalTo(3072L));
|
assertThat(result.get(2)[1], equalTo(3071L));
|
||||||
assertThat(result.get(3)[0], equalTo(3073L));
|
assertThat(result.get(3)[0], equalTo(3072L));
|
||||||
assertThat(result.get(3)[1], equalTo(4096L));
|
assertThat(result.get(3)[1], equalTo(4095L));
|
||||||
|
|
||||||
coordinator.getChunks().clear();
|
coordinator.getChunks().clear();
|
||||||
coordinator.createChucks(4096, 8196);
|
coordinator.createChucks(4096, 8196);
|
||||||
result = new ArrayList<>(coordinator.getChunks());
|
result = new ArrayList<>(coordinator.getChunks());
|
||||||
assertThat(result.size(), equalTo(5));
|
assertThat(result.size(), equalTo(5));
|
||||||
assertThat(result.get(0)[0], equalTo(4096L));
|
assertThat(result.get(0)[0], equalTo(4096L));
|
||||||
assertThat(result.get(0)[1], equalTo(5120L));
|
assertThat(result.get(0)[1], equalTo(5119L));
|
||||||
assertThat(result.get(1)[0], equalTo(5121L));
|
assertThat(result.get(1)[0], equalTo(5120L));
|
||||||
assertThat(result.get(1)[1], equalTo(6144L));
|
assertThat(result.get(1)[1], equalTo(6143L));
|
||||||
assertThat(result.get(2)[0], equalTo(6145L));
|
assertThat(result.get(2)[0], equalTo(6144L));
|
||||||
assertThat(result.get(2)[1], equalTo(7168L));
|
assertThat(result.get(2)[1], equalTo(7167L));
|
||||||
assertThat(result.get(3)[0], equalTo(7169L));
|
assertThat(result.get(3)[0], equalTo(7168L));
|
||||||
assertThat(result.get(3)[1], equalTo(8192L));
|
assertThat(result.get(3)[1], equalTo(8191L));
|
||||||
assertThat(result.get(4)[0], equalTo(8193L));
|
assertThat(result.get(4)[0], equalTo(8192L));
|
||||||
assertThat(result.get(4)[1], equalTo(8196L));
|
assertThat(result.get(4)[1], equalTo(8196L));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
|
||||||
|
|
||||||
int numberOfOps = randomIntBetween(batchSize, batchSize * 20);
|
int numberOfOps = randomIntBetween(batchSize, batchSize * 20);
|
||||||
long from = randomInt(1000);
|
long from = randomInt(1000);
|
||||||
long to = from + numberOfOps;
|
long to = from + numberOfOps - 1;
|
||||||
coordinator.createChucks(from, to);
|
coordinator.createChucks(from, to);
|
||||||
int expectedNumberOfChunks = numberOfOps / batchSize;
|
int expectedNumberOfChunks = numberOfOps / batchSize;
|
||||||
if (numberOfOps % batchSize > 0) {
|
if (numberOfOps % batchSize > 0) {
|
||||||
|
@ -163,7 +163,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
|
||||||
followShardId.getIndex(), client, client);
|
followShardId.getIndex(), client, client);
|
||||||
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 10, 1, Long.MAX_VALUE,
|
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 10, 1, Long.MAX_VALUE,
|
||||||
leaderShardId, followShardId, handler);
|
leaderShardId, followShardId, handler);
|
||||||
coordinator.createChucks(0, 20);
|
coordinator.createChucks(0, 19);
|
||||||
assertThat(coordinator.getChunks().size(), equalTo(2));
|
assertThat(coordinator.getChunks().size(), equalTo(2));
|
||||||
|
|
||||||
coordinator.start();
|
coordinator.start();
|
||||||
|
@ -196,7 +196,7 @@ public class ChunksCoordinatorTests extends ESTestCase {
|
||||||
followShardId.getIndex(), client, client);
|
followShardId.getIndex(), client, client);
|
||||||
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1000, 4, Long.MAX_VALUE,
|
ChunksCoordinator coordinator = new ChunksCoordinator(client, client, ccrExecutor, checker, 1000, 4, Long.MAX_VALUE,
|
||||||
leaderShardId, followShardId, handler);
|
leaderShardId, followShardId, handler);
|
||||||
coordinator.createChucks(0, 1000000);
|
coordinator.createChucks(0, 999999);
|
||||||
assertThat(coordinator.getChunks().size(), equalTo(1000));
|
assertThat(coordinator.getChunks().size(), equalTo(1000));
|
||||||
|
|
||||||
coordinator.start();
|
coordinator.start();
|
||||||
|
|
Loading…
Reference in New Issue