Revert "Adjust CombinedDeletionPolicy for multiple commits (#27456)"
The commit looks harmless, unfortunately it can break the engine flush
scheduler and the translog rolling. Both `uncommittedOperations` and
`uncommittedSizeInBytes` are currently calculated based on the minimum
required generation for recovery rather than the translog generation of
the last index commit. This is not correct if other index commits are
reserved for snapshotting even though we are keeping the last index
commit only.
This reverts commit e95d18ec23
.
This commit is contained in:
parent
00867e618d
commit
e0e1a92d36
|
@ -71,18 +71,12 @@ class CombinedDeletionPolicy extends IndexDeletionPolicy {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setLastCommittedTranslogGeneration(List<? extends IndexCommit> commits) throws IOException {
|
private void setLastCommittedTranslogGeneration(List<? extends IndexCommit> commits) throws IOException {
|
||||||
// We need to keep translog since the smallest translog generation of un-deleted commits.
|
// when opening an existing lucene index, we currently always open the last commit.
|
||||||
// However, there are commits that are not deleted just because they are being snapshotted (rather than being kept by the policy).
|
// we therefore use the translog gen as the one that will be required for recovery
|
||||||
// TODO: We need to distinguish those commits and skip them in calculating the minimum required translog generation.
|
final IndexCommit indexCommit = commits.get(commits.size() - 1);
|
||||||
long minRequiredGen = Long.MAX_VALUE;
|
assert indexCommit.isDeleted() == false : "last commit is deleted";
|
||||||
for (IndexCommit indexCommit : commits) {
|
long minGen = Long.parseLong(indexCommit.getUserData().get(Translog.TRANSLOG_GENERATION_KEY));
|
||||||
if (indexCommit.isDeleted() == false) {
|
translogDeletionPolicy.setMinTranslogGenerationForRecovery(minGen);
|
||||||
long translogGen = Long.parseLong(indexCommit.getUserData().get(Translog.TRANSLOG_GENERATION_KEY));
|
|
||||||
minRequiredGen = Math.min(translogGen, minRequiredGen);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert minRequiredGen != Long.MAX_VALUE : "All commits are deleted";
|
|
||||||
translogDeletionPolicy.setMinTranslogGenerationForRecovery(minRequiredGen);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public SnapshotDeletionPolicy getIndexDeletionPolicy() {
|
public SnapshotDeletionPolicy getIndexDeletionPolicy() {
|
||||||
|
|
|
@ -60,23 +60,20 @@ public class CombinedDeletionPolicyTests extends ESTestCase {
|
||||||
EngineConfig.OpenMode.OPEN_INDEX_AND_TRANSLOG);
|
EngineConfig.OpenMode.OPEN_INDEX_AND_TRANSLOG);
|
||||||
List<IndexCommit> commitList = new ArrayList<>();
|
List<IndexCommit> commitList = new ArrayList<>();
|
||||||
long count = randomIntBetween(10, 20);
|
long count = randomIntBetween(10, 20);
|
||||||
long minGen = Long.MAX_VALUE;
|
long lastGen = 0;
|
||||||
for (int i = 0; i < count; i++) {
|
for (int i = 0; i < count; i++) {
|
||||||
long lastGen = randomIntBetween(10, 20000);
|
lastGen += randomIntBetween(10, 20000);
|
||||||
minGen = Math.min(minGen, lastGen);
|
|
||||||
commitList.add(mockIndexCommitWithTranslogGen(lastGen));
|
commitList.add(mockIndexCommitWithTranslogGen(lastGen));
|
||||||
}
|
}
|
||||||
combinedDeletionPolicy.onInit(commitList);
|
combinedDeletionPolicy.onInit(commitList);
|
||||||
verify(translogDeletionPolicy, times(1)).setMinTranslogGenerationForRecovery(minGen);
|
verify(translogDeletionPolicy, times(1)).setMinTranslogGenerationForRecovery(lastGen);
|
||||||
commitList.clear();
|
commitList.clear();
|
||||||
minGen = Long.MAX_VALUE;
|
|
||||||
for (int i = 0; i < count; i++) {
|
for (int i = 0; i < count; i++) {
|
||||||
long lastGen = randomIntBetween(10, 20000);
|
lastGen += randomIntBetween(10, 20000);
|
||||||
minGen = Math.min(minGen, lastGen);
|
|
||||||
commitList.add(mockIndexCommitWithTranslogGen(lastGen));
|
commitList.add(mockIndexCommitWithTranslogGen(lastGen));
|
||||||
}
|
}
|
||||||
combinedDeletionPolicy.onCommit(commitList);
|
combinedDeletionPolicy.onCommit(commitList);
|
||||||
verify(translogDeletionPolicy, times(1)).setMinTranslogGenerationForRecovery(minGen);
|
verify(translogDeletionPolicy, times(1)).setMinTranslogGenerationForRecovery(lastGen);
|
||||||
}
|
}
|
||||||
|
|
||||||
IndexCommit mockIndexCommitWithTranslogGen(long gen) throws IOException {
|
IndexCommit mockIndexCommitWithTranslogGen(long gen) throws IOException {
|
||||||
|
|
Loading…
Reference in New Issue